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SYSTEM METHOD AND ARTICLE OF MANUFACTURE FOR CREATING CHAT 
ROOMS WITH MULTIPLE ROLES FOR MULTIPLE PARTICIPANTS 

FIELD OF THE INVENTION 

The present invention relates to education systems and more particularly to a rule based tutorial 
system that utilizes business simulations of actual environments to teach new skills. 

BACKGROUND OF THE INVENTION 

When building a knowledge based system or expert system, at least two disciplines are necessary 
to properly construct the rules that drive the knowledge base, the discipline of the knowledge 
engineer and the knowledge of the expert. The domain expert has knowledge of the domain or 
field of use of the expert system. For example, the domain expert of an expert for instructing 
students in an automotive manufacturing facility might be a process control engineer while the 
domain expert for a medical instruction system might be a doctor or a nurse. The knowledge 
engineer is a person that understands the expert system and utilizes the expert's knowledge to 
create an application for the system. In many instances, the knowledge engineer and domain 
expert are separate people who have to collaborate to construct the expert system. 

Typically, this collaboration takes the form of the knowledge engineer asking questions of the 
domain expert and incorporating the answers to these questions into the design of the system. 
This approach is labor intensive, slow and error prone. The coordination of the two separate 
disciplines may lead to problems. Although the knowledge engineer can transcribe input from 
the expert utilizing videotape, audio tape, text and other sources, efforts from people of both 
disciplines have to be expended. Further, if the knowledge engineer does not ask the right 
questions or asks the questions in an incorrect way, the information utilized to design the 
knowledge base could be incorrect. Feedback to the knowledge engineer from the expert system 
is often not available in prior art system until the construction is completed. With conventional 
system, there is a time consuming feedback loop that ties together various processes from 
knowledge acquisition to validation. 

Educational systems utilizing an expert system component often suffer from a lack of 
motivational aspects that result in a user becoming bored or ceasing to complete a training 
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program. Current training programs utilize static, hard-coded feedback with some linear video 
and graphics used to add visual appeal and illustrate concepts. These systems typically support 
one "correct" answer and navigation through the system is only supported through a single 
defined path which results in a two-dimensional generic interaction, with no business model 
5 support and a single feedback to the learner of correct or incorrect based on the selected 
response. Current tutorial systems do not architect real business simulations into the rules to 
provide a creative learning environment to a user. 

SUMMARY OF THE INVENTION 

10 According to a broad aspect of a preferred embodiment of the invention, a goal based learning 
system utilizes a rule based expert training system to provide a cognitive educational experience. 

A system is disclosed that provides a goal based learning system utilizing a rule based expert 
training system to provide a cognitive educational experience. The system provides the user 
p 1 5 with a simulated environment that presents a training opportunity to understand and solve 
W optimally. Mistakes are noted and remedial educational material presented dynamically to build 
fl j the necessary skills that a user requires for success in the business endeavor. The system utilizes 
j*j an artificial intelligence engine driving individualized and dynamic feedback with synchronized 
n audio, video, graphics and animation used to simulate real-world environment and interactions. 

t k 20 Multiple "correct" answers are integrated into the learning system to allow individualized 
Q learning experiences in which navigation through the system is at a pace controlled by the 
lQ learner. Multiple users or students can utilize the simulated environment simultaneously and 
interactively from multiple viewpoints. A robust business model provides support for realistic 
activities and allows a user to experience real world consequences for their actions and decisions 
25 and entails realtime decision-making and synthesis of the educational material. A dynamic 
feedback system is utilized that narrowly tailors feedback and focuses it based on the 
performance and characteristics of the student to assist the student in reaching a predefined goal. 

DESCRIPTION OF THE DRAWINGS 

30 The foregoing and other objects, aspects and advantages are better understood from the 

following detailed description of a preferred embodiment of the invention with reference to the 
drawings, in which: 
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Figure 1 is a block diagram of a representative hardware environment in accordance with a 
preferred embodiment; 

5 Figure 2 is a block diagram of a system architecture in accordance with a preferred embodiment; 

Figure 3 depicts the timeline and relative resource requirements for each phase of development 
for a typical application development in accordance with a preferred embodiment; 

10 Figure 4 depicts the potential savings in both functional and technical tasks in accordance with a 
preferred embodiment; 

Figure 5 illustrates commonalties in accordance with a preferred embodiment; 

U 

g 1 5 Figure 6 illustrates a development architecture approach in accordance with a preferred 
Q embodiment; 
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jy Figure 7 illustrates a small segment of a domain model for claims handlers in the auto insurance 
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n industry in accordance with a preferred embodiment; 
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|| Figure 8 illustrates an instantiated domain model in accordance with a preferred embodiment; 

Figure 9 illustrates an insurance underwriting profile in accordance with a preferred 
embodiment; 

25 

Figure 10 illustrates a transformation component in accordance with a preferred embodiment; 

Figure 11 illustrates the use of a toolbar to navigate and access application level features in 
accordance with a preferred embodiment; 

30 

Figure 12 is a GBS display in accordance with a preferred embodiment; 
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Figure 13 is a feedback display in accordance with a preferred embodiment; 

Figure 14 illustrates a display in which a student has made some mistakes in accordance with a 
preferred embodiment; 

Figure 15 illustrates a journal entry simulation in accordance with a preferred embodiment; 

Figure 16 illustrates a simulated Bell Phone Bill journal entry in accordance with a preferred 
embodiment; 

Figure 17 illustrates a feedback display in accordance with a preferred embodiment; 

Figures 18 and 19 illustrate a feedback display in accordance with a preferred embodiment; 

Figure 20 illustrates a feedback display in accordance with a preferred embodiment; 

Figure 21 illustrates a simulation display in accordance with a preferred embodiment; 

Figure 22 illustrates the steps of the first scenario in accordance with a preferred embodiment; 

Figure 23 and 24 illustrate the steps associated with a build scenario in accordance with a 
preferred embodiment; 

Figure 25 illustrates how the tool suite supports student administration in accordance with a 
preferred embodiment; 

Figure 26 illustrates a suite to support a student interaction in accordance with a preferred 
embodiment; 

Figure 27 illustrates the remediation process in accordance with a preferred embodiment; 
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Figure 28 illustrates a display of journalization transactions in accordance with a preferred 
embodiment; 

Figure 29 illustrates the objects for the journalization task in accordance with a preferred 
embodiment; 

Figure 30 illustrates the mapping of a source item to a target item in accordance with a preferred 
embodiment; 

Figure 31 illustrates target group bundles in accordance with a preferred embodiment; 

Figure 32 illustrates a TargetGroup Hierarchy in accordance with a preferred embodiment; 

Figure 33 illustrates a small section the amount of feedback in accordance with a preferred 
embodiment; 

Figure 34 illustrates an analysis of rules in accordance with a preferred embodiment; 

Figure 35 illustrates a feedback selection in accordance with a preferred embodiment; 

Figure 36 is a flowchart of the feedback logic in accordance with a preferred embodiment; 

Figure 37 illustrates an example of separating out some mistakes for the interface to catch and 
others for the ICAT to catch has positive and negative impacts in accordance with a preferred 
embodiment; 

Figure 38 is a block diagram of the hierarchical relationship of a transaction in accordance with a 
preferred embodiment; 

Figure 39 is a block diagram illustrating the feedback hierarchy in accordance with a preferred 
embodiment; 
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Figure 40 is a block diagram illustrating how the simulation engine is architected into a preferred 
embodiment of the invention; 

Figure 41 is a block diagram setting forth the architecture of a simulation model in accordance 
with a preferred embodiment; 

Figure 42 illustrates the arithmetic steps in accordance with a preferred embodiment; 

Figure 43 illustrates a drag & drop input operation in accordance with a preferred embodiment; 

Figure 44 illustrates list object processing in accordance with a preferred embodiment; 

Figure 45 illustrates the steps for configuring a simulation in accordance with a preferred 
embodiment; 

Figure 46 illustrates a distinct output in accordance with a preferred embodiment; 

Figure 47 is a block diagram presenting the detailed architecture of a system dynamics model in 
accordance with a preferred embodiment; 

Figure 48 is graphical representation of the object model which is utilized to instantiate the 
system dynamic engine in accordance with a preferred embodiment. 

Figure 49 is a PInput Cell for a simulation model in accordance with a preferred embodiment; 

Figure 50 is a PInput backup cell in a simulation model in accordance with a preferred 
embodiment; 

Figure 51 is a display illustrating a POutput cell in accordance with a preferred embodiment. The 
steps required to configure the POutput are presented below; 
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Figure 52 is an overview diagram of the logic utilized for initial configuration in accordance with 
a preferred embodiment; 

Figure 53 is a display of the source item and target configuration in accordance with a preferred 
5 embodiment; 

Figure 54 is a display of video information in accordance with a preferred embodiment; 

Figure 55 illustrates a display depicting configured rules in accordance with a preferred 
10 embodiment; 

Figure 56 illustrates feedback for configured rules in accordance with a preferred embodiment; 



Figure 57 illustrates a display with follow-up configuration questions in accordance with a 
Q 1 5 preferred embodiment; 
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Figure 58 illustrates configuration of aggregate rules in accordance with a preferred embodiment; 

Figure 59 illustrates a set of coach items in accordance with a preferred embodiment; 

Figure 60 is an ICA Meeting Configuration tool display in accordance with a preferred 
embodiment; 

Figure 61 illustrates an ICA utility in accordance with a preferred embodiment; 

Figure 62 illustrates a configuration utility display in accordance with a preferred embodiment; 

Figure 63 illustrates an object editor toolbar in accordance with a preferred embodiment; 

30 Figure 64 illustrates the seven areas that can be configured for a simulation in accordance with a 
preferred embodiment; 
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Figure 65 illustrates a display that defines inputs in accordance with a preferred embodiment; 

Figure 66 illustrates a list editor in accordance with a preferred embodiment; 

Figure 67A illustrates a define student display in accordance with a preferred embodiment; 

Figure 67B illustrates a ControlSourceltem display in accordance with a preferred embodiment; 

Figure 68 illustrates a simulation workbench in accordance with a preferred embodiment; 

Figure 69 illustrates an object viewer in accordance with a preferred embodiment. As shown in 

Figure 70 illustrates an Object Viewer Configuration in an Utilities menu in accordance with a 
preferred embodiment; 

Figure 71 illustrates a log viewer in accordance with a preferred embodiment; 

Figure 72 illustrates a Doc Maker display in accordance with a preferred embodiment; 

Figure 73 illustrates a Feedback display in accordance with a preferred embodiment; 

Figure 74 is an object editor display that illustrates the use of references in accordance with a 
preferred embodiment; 

Figure 75 presents the detailed design of smart spreadsheets in accordance with a preferred 
embodiment; 

Figure 76 presents the assembly of a telephone operator training simulation in accordance with a 
preferred embodiment; 

Figure 77 presents the domain expert's work station utilized to assemble a simulation in 
accordance with a preferred embodiment; 
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Figure 78 presents multiple domain expert's work stations linked/networked to collaborate on 
the assembly of a simulation in accordance with a preferred embodiment; 

5 Figure 79 presents the detailed flowchart of a telephone operator training simulation in 
accordance with a preferred embodiment; 

Figure 80 presents a user training station linked/networked to the simulation server in accordance 
with a preferred embodiment; 

10 

Figure 81 presents a detailed flowchart of a user query of the knowledge base in accordance with 
a preferred embodiment; 

JJ Figure 82 presents an example of feedback from a coach in accordance with a preferred 
Hi 5 embodiment: 



pj Figure 83 presents multiple user's training stations linked/networked to collaborate in the 
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f n execution of a simulation in accordance with a preferred embodiment; 
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;u20 Figure 84 is a block diagram of a system environment in accordance with a preferred 



embodiment; 



Figure 85 is a block diagram of a virtual consulting channel in accordance with a preferred 
embodiment; 

25 

Figures 86 and 87 are data structures for a virtual consulting environment in accordance with a 
preferred embodiment; and 

Figures 88 - 99 are flowcharts of a virtual university system in accordance with a preferred 
30 embodiment. 
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DETAILED DESCRIPTION 

A preferred embodiment of a system in accordance with the present invention is preferably 
practiced in the context of a personal computer such as an IBM compatible personal computer, 
Apple Macintosh computer or UNIX based workstation. A representative hardware environment 
is depicted in Figure 1, which illustrates a typical hardware configuration of a workstation in 
accordance with a preferred embodiment having a central processing unit 110, such as a 
microprocessor, and a number of other units interconnected via a system bus 112. The 
workstation shown in Figure 1 includes a Random Access Memory (RAM) 114, Read Only 
Memory (ROM) 116, an I/O adapter 118 for connecting peripheral devices such as disk storage 
units 120 to the bus 112, a user interface adapter 122 for connecting a keyboard 124, a mouse 
126, a speaker 128, a microphone 132, and/or other user interface devices such as a touch screen 
(not shown) to the bus 112, communication adapter 134 for connecting the workstation to a 
communication network (e.g., a data processing network) and a display adapter 136 for 
connecting the bus 112 to a display device 138. The workstation typically has resident thereon 
an operating system such as the Microsoft Windows NT or Windows/95 Operating System (OS), 
the IBM OS/2 operating system, the MAC OS, or UNIX operating system. Those skilled in the 
art will appreciate that the present invention may also be implemented on platforms and 
operating systems other than those mentioned. 

A preferred embodiment is written using JAVA, C, and the C++ language and utilizes object 
oriented programming methodology. Object oriented programming (OOP) has become 
increasingly used to develop complex applications. As OOP moves toward the mainstream of 
software design and development, various software solutions require adaptation to make use of 
the benefits of OOP. A need exists for these principles of OOP to be applied to a messaging 
interface of an electronic messaging system such that a set of OOP classes and objects for the 
messaging interface can be provided. 
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OOP is a process of developing computer software using objects, including the steps of 
analyzing the problem, designing the system, and constructing the program. An object is a 
software package that contains both data and a collection of related structures and procedures. 
Since it contains both data and a collection of structures and procedures, it can be visualized as a 
self-sufficient component that does not require other additional structures, procedures or data to 
perform its specific task. OOP, therefore, views a computer program as a collection of largely 
autonomous components, called objects, each of which is responsible for a specific task. This 
concept of packaging data, structures, and procedures together in one component or module is 
called encapsulation. 

In general, OOP components are reusable software modules which present an interface that 
conforms to an object model and which are accessed at run-time through a component 
integration architecture. A component integration architecture is a set of architecture 
mechanisms which allow software modules in different process spaces to utilize each others 
capabilities or functions. This is generally done by assuming a common component object 
model on which to build the architecture. It is worthwhile to differentiate between an object and 
a class of objects at this point. An object is a single instance of the class of objects, which is 
often just called a class. A class of objects can be viewed as a blueprint, from which many 
objects can be formed. 

OOP allows the programmer to create an object that is a part of another object. For example, the 
object representing a piston engine is said to have a composition-relationship with the object 
representing a piston. In reality, a piston engine comprises a piston, valves and many other 
components; the fact that a piston is an element of a piston engine can be logically and 
semantically represented in OOP by two objects, 

OOP also allows creation of an object that "depends from" another object. If there are two 
objects, one representing a piston engine and the other representing a piston engine wherein the 
piston is made of ceramic, then the relationship between the two objects is not that of 
composition. A ceramic piston engine does not make up a piston engine. Rather it is merely one 
kind of piston engine that has one more limitation than the piston engine; its piston is made of 
ceramic. In this case, the object representing the ceramic piston engine is called a derived object, 
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and it inherits all of the aspects of the object representing the piston engine and adds further 
limitation or detail to it. The object representing the ceramic piston engine "depends from" the 
object representing the piston engine. The relationship between these objects is called 
inheritance. 

When the object or class representing the ceramic piston engine inherits all of the aspects of the 
objects representing the piston engine, it inherits the thermal characteristics of a standard piston 
defined in the piston engine class. However, the ceramic piston engine object overrides these 
ceramic specific thermal characteristics, which are typically different from those associated with 
a metal piston. It skips over the original and uses new functions related to ceramic pistons. 
Different kinds of piston engines have different characteristics, but may have the same 
underlying functions associated with it (e.g., how many pistons in the engine, ignition sequences, 
lubrication, etc.). To access each of these functions in any piston engine object, a programmer 
would call the same functions with the same names, but each type of piston engine may have 
different/overriding implementations of functions behind the same name. This ability to hide 
different implementations of a function behind the same name is called polymorphism and it 
greatly simplifies communication among objects. 

With the concepts of composition-relationship, encapsulation, inheritance and polymorphism, an 
object can represent just about anything in the real world. In fact, our logical perception of the 
reality is the only limit on determining the kinds of things that can become objects in object- 
oriented software. Some typical categories are as follows: 

• Objects can represent physical objects, such as automobiles in a traffic-flow simulation, 
electrical components in a circuit-design program, countries in an economics model, or 
aircraft in an air-traffic-control system. 

• Objects can represent elements of the computer-user environment such as windows, 
menus or graphics objects. 

• An object can represent an inventory, such as a personnel file or a table of the latitudes 
and longitudes of cities. 

• An object can represent user-defined data types such as time, angles, and complex 
numbers, or points on the plane. 
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With this enormous capability of an object to represent just about any logically separable 
matters, OOP allows the software developer to design and implement a computer program that is 
a model of some aspects of reality, whether that reality is a physical entity, a process, a system, 
or a composition of matter. Since the object can represent anything, the software developer can 
create an object which can be used as a component in a larger software project in the future. 

If 90% of a new OOP software program consists of proven, existing components made from 
preexisting reusable objects, then only the remaining 10% of the new software project has to be 
written and tested from scratch. Since 90% already came from an inventory of extensively tested 
reusable objects, the potential domain from which an error could originate is 10% of the 
program. As a result, OOP enables software developers to build objects out of other, previously 
built objects. 

This process closely resembles complex machinery being built out of assemblies and sub- 
assemblies. OOP technology, therefore, makes software engineering more like hardware 
engineering in that software is built from existing components, which are available to the 
developer as objects. All this adds up to an improved quality of the software as well as an 
increased speed of its development. 

Programming languages are beginning to fully support the OOP principles, such as 
encapsulation, inheritance, polymorphism, and composition-relationship. With the advent of the 
C++ language, many commercial software developers have embraced OOP. C++ is an OOP 
language that offers a fast, machine-executable code. Furthermore, C++ is suitable for both 
commercial-application and systems-programming projects. For now, C++ appears to be the 
most popular choice among many OOP programmers, but there is a host of other OOP 
languages, such as Smalltalk, Common Lisp Object System (CLOS), and Eiffel. Additionally, 
OOP capabilities are being added to more traditional popular computer programming languages 
such as Pascal. 

The benefits of object classes can be summarized, as follows: 

• Objects and their corresponding classes break down complex programming problems into 
many smaller, simpler problems. 
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• Encapsulation enforces data abstraction through the organization of data into small, 
independent objects that can communicate with each other. Encapsulation protects the 
data in an object from accidental damage, but allows other objects to interact with that 
data by calling the object's member functions and structures. 

• Subclassing and inheritance make it possible to extend and modify objects through 
deriving new kinds of objects from the standard classes available in the system. Thus, 
new capabilities are created without having to start from scratch. 

• Polymorphism and multiple inheritance make it possible for different programmers to 
mix and match characteristics of many different classes and create specialized objects 
that can still work with related objects in predictable ways. 

• Class hierarchies and containment hierarchies provide a flexible mechanism for modeling 
real-world objects and the relationships among them. 

• Libraries of reusable classes are useful in many situations, but they also have some 
limitations. For example: 

• Complexity. In a complex system, the class hierarchies for related classes can become 
extremely confusing, with many dozens or even hundreds of classes. 

• Flow of control. A program written with the aid of class libraries is still responsible for 
the flow of control (i.e., it must control the interactions among all the objects created 
from a particular library). The programmer has to decide which functions to call at what 
times for which kinds of objects. 

• Duplication of effort. Although class libraries allow programmers to use and reuse many 
small pieces of code, each programmer puts those pieces together in a different way. 
Two different programmers can use the same set of class libraries to write two programs 
that do exactly the same thing but whose internal structure (i.e., design) may be quite 
different, depending on hundreds of small decisions each programmer makes along the 
way. Inevitably, similar pieces of code end up doing similar things in slightly different 
ways and do not work as well together as they should. 

Class libraries are very flexible. As programs grow more complex, more programmers are 
forced to reinvent basic solutions to basic problems over and over again. A relatively new 
extension of the class library concept is to have a framework of class libraries. This framework 
is more complex and consists of significant collections of collaborating classes that capture both 
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the small scale patterns and major mechanisms that implement the common requirements and 
design in a specific application domain. They were first developed to free application 
programmers from the chores involved in displaying menus, windows, dialog boxes, and other 
standard user interface elements for personal computers. 

Frameworks also represent a change in the way programmers think about the interaction between 
the code they write and code written by others. In the early days of procedural programming, the 
programmer called libraries provided by the operating system to perform certain tasks, but 
basically the program executed down the page from start to finish, and the programmer was 
solely responsible for the flow of control. This was appropriate for printing out paychecks, 
calculating a mathematical table, or solving other problems with a program that executed in just 
one way. 

The development of graphical user interfaces began to turn this procedural programming 
arrangement inside out. These interfaces allow the user, rather than program logic, to drive the 
program and decide when certain actions should be performed. Today, most personal computer 
software accomplishes this by means of an event loop which monitors the mouse, keyboard, and 
other sources of external events and calls the appropriate parts of the programmer's code 
according to actions that the user performs. The programmer no longer determines the order in 
which events occur. Instead, a program is divided into separate pieces that are called at 
unpredictable times and in an unpredictable order. By relinquishing control in this way to users, 
the developer creates a program that is much easier to use. Nevertheless, individual pieces of the 
program written by the developer still call libraries provided by the operating system to 
accomplish certain tasks, and the programmer must still determine the flow of control within 
each piece after it's called by the event loop. Application code still "sits on top of the system. 

Even event loop programs require programmers to write a lot of code that should not need to be 
written separately for every application. The concept of an application framework carries the 
event loop concept further. Instead of dealing with all the nuts and bolts of constructing basic 
menus, windows, and dialog boxes and then making these things all work together, programmers 
using application frameworks start with working application code and basic user interface 
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elements in place. Subsequently, they build from there by replacing some of the generic 
capabilities of the framework with the specific capabilities of the intended application. 

Application frameworks reduce the total amount of code that a programmer has to write from 
scratch. However, because the framework is really a generic application that displays windows, 
supports copy and paste, and so on, the programmer can also relinquish control to a greater 
degree than event loop programs permit. The framework code takes care of almost all event 
handling and flow of control, and the programmer's code is called only when the framework 
needs it (e.g., to create or manipulate a proprietary data structure). 

A programmer writing a framework program not only relinquishes control to the user (as is also 
true for event loop programs), but also relinquishes the detailed flow of control within the 
program to the framework. This approach allows the creation of more complex systems that 
work together in interesting ways, as opposed to isolated programs, having custom code, being 
created over and over again for similar problems. 

Thus, as is explained above, a framework basically is a collection of cooperating classes that 
make up a reusable design solution for a given problem domain. It typically includes objects that 
provide default behavior (e.g., for menus and windows), and programmers use it by inheriting 
some of that default behavior and overriding other behavior so that the framework calls 
application code at the appropriate times. 

There are three main differences between frameworks and class libraries: 

• Behavior versus protocol. Class libraries are essentially collections of behaviors that you 
can call when you want those individual behaviors in your program. A framework, on 
the other hand, provides not only behavior but also the protocol or set of rules that govern 
the ways in which behaviors can be combined, including rules for what a programmer is 
supposed to provide versus what the framework provides. 

• Call versus override. With a class library, the code the programmer instantiates objects 
and calls their member functions. It's possible to instantiate and call objects in the same 
way with a framework (i.e., to treat the framework as a class library), but to take full 
advantage of a framework's reusable design, a programmer typically writes code that 
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overrides and is called by the framework. The framework manages the flow of control 
among its objects. Writing a program involves dividing responsibilities among the 
various pieces of software that are called by the framework rather than specifying how 
the different pieces should work together. 
• Implementation versus design. With class libraries, programmers reuse only 

implementations, whereas with frameworks, they reuse design. A framework embodies 
the way a family of related programs or pieces of software work. It represents a generic 
design solution that can be adapted to a variety of specific problems in a given domain. 
For example, a single framework can embody the way a user interface works, even 
though two different user interfaces created with the same framework might solve quite 
different interface problems. 

Thus, through the development of frameworks for solutions to various problems and 
programming tasks, significant reductions in the design and development effort for software can 
be achieved. A preferred embodiment of the invention utilizes HyperText Markup Language 
(HTML) to implement documents on the Internet together with a general-purpose secure 
communication protocol for a transport medium between the client and the Newco. HTTP or 
other protocols could be readily substituted for HTML without undue experimentation. 
Information on these products is available in T. Berners-Lee, D. Connoly, "RFC 1866: Hypertext 
Markup Language - 2.0" (Nov. 1995); and R. Fielding, H, Frystyk, T. Berners-Lee, J. Gettys and 
J.C. Mogul, "Hypertext Transfer Protocol - HTTP/1 . 1 : HTTP Working Group Internet Draft" 
(May 2, 1996). HTML is a simple data format used to create hypertext documents that are 
portable from one platform to another. HTML documents are SGML documents with generic 
semantics that are appropriate for representing information from a wide range of domains. 
HTML has been in use by the World-Wide Web global information initiative since 1990. 
HTML is an application of ISO Standard 8879; 1986 Information Processing Text and Office 
Systems; Standard Generalized Markup Language (SGML). 

To date, Web development tools have been limited in their ability to create dynamic Web 
applications which span from client to server and interoperate with existing computing resources. 
Until recently, HTML has been the dominant technology used in development of Web-based 
solutions. However, HTML has proven to be inadequate in the following areas: 
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• Poor performance; 

• Restricted user interface capabilities; 

• Can only produce static Web pages; 

• Lack of interoperability with existing applications and data; and 

• Inability to scale. 

Sun Microsystem's Java language solves many of the client-side problems by: 

• Improving performance on the client side; 

• Enabling the creation of dynamic, real-time Web applications; and 

• Providing the ability to create a wide variety of user interface components. 

With Java, developers can create robust User Interface (UI) components. Custom "widgets" (e.g., 
real-time stock tickers, animated icons, etc.) can be created, and client-side performance is 
improved. Unlike HTML, Java supports the notion of client-side validation, offloading 
appropriate processing onto the client for improved performance. Dynamic, real-time Web 
pages can be created. Using the above-mentioned custom UI components, dynamic Web pages 
can also be created. 

Sun's Java language has emerged as an industry-recognized language for "programming the 
Internet." Sun defines Java as: "a simple, object-oriented, distributed, interpreted, robust, 
secure, architecture-neutral, portable, high-performance, multithreaded, dynamic, buzzword- 
compliant, general-purpose programming language. Java supports programming for the Internet 
in the form of platform-independent Java applets." Java applets are small, specialized 
applications that comply with Sun's Java Application Programming Interface (API) allowing 
developers to add "interactive content" to Web documents (e.g., simple animations, page 
adornments, basic games, etc.). Applets execute within a Java-compatible browser (e.g., 
Netscape Navigator) by copying code from the server to client. From a language standpoint, 
Java's core feature set is based on C++. Sun's Java literature states that Java is basically, "C++ 
with extensions from Objective C for more dynamic method resolution." 

Another technology that provides similar function to JAVA is provided by Microsoft and ActiveX 
Technologies, to give developers and Web designers wherewithal to build dynamic content for the 

18 



AND1P045.P - J ^ 

Internet and personal computers. ActiveX includes tools for developing animation, 3-D virtual 
reality, video and other multimedia content. The tools use Internet standards, work on multiple 
platforms, and are being supported by over 100 companies. The group's building blocks are called 
ActiveX Controls, small, fast components that enable developers to embed parts of software in 
hypertext markup language (HTML) pages. ActiveX Controls work with a variety of 
programming languages including Microsoft Visual C++, Borland Delphi, Microsoft Visual Basic 
programming system and, in the future, Microsoft's development tool for Java, code named 
"Jakarta." ActiveX Technologies also includes ActiveX Server Framework, allowing developers 
to create server applications. One of ordinary skill in the art readily recognizes that ActiveX could 
be substituted for JAVA without undue experimentation to practice the invention. 

A simulation engine in accordance with a preferred embodiment is based on a Microsoft Visual 
Basic component developed to help design and test feedback in relation to a Microsoft Excel 
spreadsheet. These spreadsheet models are what simulate actual business functions and become a 
task that will be performed by a student The Simulation Engine accepts simulation inputs and 
calculates various outputs and notifies the system of the status of the simulation at a given time 
in order to obtain appropriate feedback. 

Relationship of Components 

The simulation model executes the business function that the student is learning and is therefore 
the center point of the application. An activity 'layer' allows the user to visually guide the 
simulation by passing inputs into the simulation engine and receiving an output from the 
simulation model. For example, if the student was working on an income statement activity, the 
net sales and cost of goods sold calculations are passed as inputs to the simulation model and the 
net income value is calculated and retrieved as an output. As calculations are passed to and 
retrieved from the simulation model, they are also passed to the Intelligent Coaching Agent 
(ICA). The ICA analyzes the Inputs and Outputs to the simulation model and generates 
feedback based on a set of rules. This feedback is received and displayed through the Visual 
Basic Architecture. 

Figure 2 is a block diagram of a system architecture in accordance with a preferred embodiment. 
The Presentation 'layer' 210 is separate from the activity 'layer' 220 and communication is 
facilitated through a set of messages 230 that control the display specific content topics. A 

19 



AND1P045.P 



preferred embodiment enables knowledge workers 200 & 201 to acquire complex skills rapidly, 
reliably and consistently across an organization to deliver rapid acquisition of complex skills. 
This result is achieved by placing individuals in a simulated business environment that "looks 
and feels" like real work, and challenging them to make decisions which support a business 5 
5 strategic objectives utilizing highly effective learning theory (e.g., goal based learning, learn by 
doing, failure based learning, etc.), and the latest in multimedia user interfaces, coupled with 
three powerful, integrated software components. The first of these components is a software 
Solution Construction Aid (SCA) 230 consisting of a mathematical modeling tool 234 which 
simulates business outcomes of an individual's collective actions over a period of time. The 
10 second component is a knowledge system 250 consisting of an HTML content layer which 
organizes and presents packaged knowledge much like an online text book with practice 
exercises, video war stories, and a glossary. The third component is a software tutor 270 
comprising an artificial intelligence engine 240 which generates individualized coaching 
jjsq messages based on decisions made by learner. 

015 

Q 

m Feedback is unique for each individual completing the course and supports client cultural 
*y messages 242 "designed into" the course. A business simulation methodology that includes 

m 

in support for content acquisition, story line design, interaction design, feedback and coaching 

! s delivery, and content delivery is architected into the system in accordance with a preferred 

20 embodiment. A large number of "pre-designed" learning interactions such as drag and drop 

O 

ffo association of information 238, situation assessment/action planning, interviewing (one-on-one, 

%3 one-to-many), presenting (to a group of experts/executives), metering of performance (handle 

Li. 

now, handle later), "time jumping" for impact of decisions, competitive landscape shift (while 
"time jumping", competitors merge, customers are acquired, etc.) and video interviewing with 
25 automated note taking are also included in accordance with a preferred embodiment. 

Business simulation in accordance with a preferred embodiment delivers training curricula in an 
optimal manner. This is because such applications provide effective training that mirrors a 
student's actual work environment. The application of skills "on the job" facilitates increased 
30 retention and higher overall job performance. While the results of such training applications are 
impressive, business simulations are very complex to design and build correctly. These 
simulations are characterized by a very open-ended environment, where students can go through 
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the application along any number of paths, depending on their learning style and prior 
experiences/knowledge. 

A category of learning approaches called Learn by Doing, is commonly used as a solution to 
support the first phase (Learn) of the Workforce Performance Cycle. However, it can also be a 
solution to support the second phase (Perform) of the cycle to enable point of need learning 
during job performance. By adopting the approach presented, some of the benefits of a 
technology based approach for building business simulation solutions which create more 
repeatable, predictable projects resulting in more perceived and actual user value at a lower cost 
and in less time are highlighted. 

Most corporate training programs today are misdirected because they have failed to focus 
properly on the purpose of their training. These programs have confused the memorization of 
facts with the ability to perform tasks; the knowing of "that" with the knowing of "how". By 
adopting the methods of traditional schools, businesses are teaching a wide breadth of 
disconnected, decontextualized facts and figures, when they should be focused on improved 
performance. How do you teach performance, when lectures, books, and tests inherently are 
designed around facts and figures? Throw away the lectures, books, and tests. The best way to 
prepare for high performance is to perform; experience is the best teacher! Most business 
leaders agree that workers become more effective the more time they spend in their jobs. The 
best approach for training novice employees, therefore, would be letting them learn on the job, 
acquiring skills in their actual work environment. The idea of learning-by-doing is not 
revolutionary, yet it is resisted in business and academia. Why is this so, if higher competence is 
universally desired? 

Learners are reluctant to adopt learning-by-doing because they are frightened of failure. People 
work hard to avoid making mistakes in front of others. Business leaders are hesitant to 
implement learning-by-doing because novice failure may have dramatic safety, legal and 
financial implications. Imagine a novice pilot learning-by-doing as he accelerates a large jet 
plane down a runway; likewise, consider a new financial analyst learning-by-doing as he 
structures a multi-million dollar financial loan. Few employers are willing to endure such 
failures to have a more competent workforce. 
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The concerns of employee and employer can be relieved if the training (and accompanying 
failure) didn't occur in front of co-workers and clients, if it didn't jeopardize a multi-million 
dollar aircraft or a multi-million dollar deal What if the training was performed privately, in a 
5 richly modeled simulation of the workers actual job? In a simulated environment, failure would 
result in dedicated instruction instead of embarrassment, injury, or monetary losses. Simulated 
environments provide a sense of liberation for exploration that does not exist in the real world. 
Knowing that the consequences of experimentation will unlikely be dire, learners are able to 
explore the "what if..." inherent in us all In this way, the best way to prepare for high 
10 performance is to simulate actual performance. New media technologies utilizing multimedia 
provide the possibility to create such business simulation experiences. 

Even if companies didn't make the mistake of focusing on "what" learning vs. "how" learning, 
% h they still tend to have the overly narrow view of education/training as something that only 

S-J15 occurs prior to workers being asked to actually perform their job. Learning is something that is 

Q 

m constantly occurring, and doesn't cease once "real work" has begun. The closer new lessons 
p; occur in time with the application of those lessons, the greater the resultant learning. This fact 
!yl helps to explain some of the reasoning behind the benefits of business simulation, described in 
I . the previous section. In those systems, all new lessons are taught in close relationship to their 
►*20 real world use; everything is in context and, most importantly, are presented at the appropriate 
|S time. But as the properly trained worker performs their job, the working environment changes. 
%3 New demands occur, and new methods and rules are developed. As these events occur, there is a 

need for new support/training that, in most cases, must wait to be addressed until the next "pre- 

performance" training session. 

25 

In these cases, the need (or demand) for additional training doesn't match the supply. This lag 
between a training need and the fulfilling lesson has a dramatic negative impact on productivity, 
accuracy, and customer satisfaction. Workers need to have the opportunity to learn while they 
are performing. Just as during pre-performance training, one powerful mechanism for 
30 identifying and correcting (simulated) performance problems is to have an expert available at all 
time to watch your actions and remediate when appropriate. This, obviously, is too costly and 
time intensive of an approach to be practical with actual experts. But what if workers had access 
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to a support system that provided the majority of the benefits of a real expert, transparently 
integrated into their work environment? Such a system would provide advice at key moments in 
the work flow for problem resolution and/or process improvement, tools to ease task completion, 
reference material of best practice knowledge, and point of need training courses. With a 
5 support system that proactively assists the worker in performance of their job tasks at a higher 
level of competency, productivity and customer satisfaction (both internal and external) would 
soar. 

The key to such a support system is that it is seamlessly integrated into the business system that 
10 the knowledge worker uses to execute their job tasks. Workers don't need to go "off-line" or 

seek out cryptic information buried within paper manuals and binders for guidance or to find the 
answer to queries. All the support components are made available through the same applications 
the worker's use, at the point in which they need them, tailored to the individual to show "how", 
m not just "what". Learning would be occurring all the time, with little distinction between 

■fez? 

© 1 5 performing and improving performance. 

O 

m 

jjjjj Establishing that training should focus on performance (how), rather than facts (what), and 
111 extending the model of learning to include assistance while performing, rather than only before 
L performance, still leaves us dangerously exposed in preparing to compete in the new, chaotic 
P k 20 economy. As was mentioned in the opening of this paper, the pace of change in business today 
m is whiplash fast. Not only are new methods of doing business evolving every 1 8-24 months, new 
ff competitors emerge, dominate, and fade in time periods businesses used to take to perform 

demographic studies. Now more than ever, those who do not reinvent themselves on a regular 

basis will be fossilized by the pace of change. 

25 

Even the best pre-performance training and the most advanced performance support tools are 
destined to be outdated if there isn't a fresh supply of real-world requirements and lessons 
learned being fed back as inputs for the next go 'round. Innovation is a key step in the 
Workforce Performance Cycle. This step requires business to employ Stephen Covey's famous 
30 habit of "sharpening the saw", or "take time to be fast". 
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There is an untold wealth of information buried within the heads of business users responsible 
for implementing the steps outlined in their pre-performance training and performance support 
tools. No other group within an organization can more accurately assess the effectiveness of 
current methods, or project needed changes that will have dramatic future impact. This step of 
5 reflecting on the current and past state of affairs, uncovering new approaches by identifying 
what is working and what is not, and adapting accordingly for the future is the last phase of the 
learning/performance cycle. 

Innovation to fuel future training and performance support comes directly from the community 
10 most closely tied to task performance. Effective businesses need to develop and cultivate a 
mechanism for communication and collaboration among the experts in these communities to 
more efficiently benefit from their collective wisdom. In today's business, that which is evident 
to your business is evident to nearly all your competitors as well. The competitive advantage lies 
f I in uncovering that which is unexpected or not immediately apparent, adapting your business 
Pl5 processes to exploit the discovery, and quickly, but effectively, educating your workforce on the 
|1 new policies and procedures, all before the competition catches on or the market changes again. 

m 
m 

Ul This innovation process is the critical final step in continuous education of the most effective and 
L up-to-date policies, procedures, and information. Without formalized innovation, companies not 
N 20 only risk being a step behind the ever advancing competition, but compound the problem by 
|l continuing to train their personnel with outdated strategies and information. One way to 
© formalize this vital step in the Workforce Performance Cycle is to construct Virtual Learning 

Communities, where many 'experts' can share experiences, submit ideas for improvements, play 
out "what-if ' scenarios, and contribute on complex problems that may be insurmountable 
25 without significant collaboration with others. Such Learning Communities could nurture up-to- 
date discussion of what is actually happening within a business, eliminating the traditional 
information-passing lag that plagues many business as new data travels through corporate 
hierarchies. This increased nimbleness would help organizations quickly address new 
competitive trends and outdated strategies, identify potential solutions, and implement improved 
30 processes in the form of updated training and performance support reference materials. 
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Currently, a typical BusSim engagement takes between one and two years to complete and 
requires a variety of both functional and technical skills. Figure 3 depicts the timeline and 
relative resource requirements for each phase of development for a typical application 
development in accordance with a preferred embodiment. The chart clearly depicts the 

5 relationship between the large number of technical resources required for both the build and test 
phases of development. This is because the traditional development process used to build 
BusSim solutions reflects more of a "one off 1 philosophy, where development is done from 
scratch in a monolithic fashion, with little or no reuse from one application to the next. This lack 
of reuse makes this approach prohibitively expensive, as well as lengthy, for future BusSim 

10 projects. 

The solution to this problem is to put tools in the hands of instructional designers that allows 
them to create their BusSim designs and implement them without the need for programmers to 
write code. And to put application architectures that integrate with the tools in the hands of 
1 5 developers, providing them with the ability to quickly deliver solutions for a number of different 
platforms. The reuse, then, comes in using the tools and architectures from one engagement to 
another. Both functional and technical resources carry with them the knowledge of how to use 
the technology, which also has an associated benefit of establishing a best-practice development 
methodology for BusSim engagements. 

20 

The tools and architectures described herein are part of a next-generation Business Simulation 
delivery framework that will reduce the total effort necessary to build solutions in accordance 
with a preferred embodiment. Figure 4 depicts the potential savings in both functional and 
technical tasks in accordance with a preferred embodiment. 

25 

Development Cycle Activities 

Design Phase 

In the Design Phase, instructional designers become oriented to the content area and begin to 
conceptualize an instructional approach. They familiarize themselves with the subject matter 
30 through reading materials and interviews with Subject Matter Experts (SMEs). They also 

identify learning objectives from key client contacts. Conceptual designs for student interactions 
and interface layouts also begin to emerge. After the conceptual designs have taken shape, Low- 



25 



' 1 ) } 

AND1P045.P - J 



Fi user testing (a.k.a. Conference Room Piloting) is performed. Students interact with interface 
mock-ups while facilitators observe and record any issues. Finally, detailed designs are created 
that incorporate findings. These detailed designs are handed off to the development team for 
implementation. 

The design phase has traditionally been fraught with several problems. Unlike a traditional 
business system, BusSim solutions are not rooted in tangible business processes, so requirements 
are difficult to identify in a concrete way. This leaves instructional designers with a 'blue sky' 
design problem. With few business-driven constraints on the solution, shallow expertise in the 
content area, and limited technical skills, instructional designers have little help in beginning a 
design. Typically, only experienced designers have been able to conjure interface, analysis, and 
feedback designs that meet the learning objectives yet remain technically feasible to implement. 
To compound the problem, BusSim solutions are very open ended in nature. The designer must 
anticipate a huge combination of student behavior to design feedback that is helpful and realistic. 

Build Phase 

During the build phase, the application development team uses the detailed designs to code the 
application. Coding tasks include the interfaces and widgets that the student interacts with. The 
interfaces can be made up of buttons, grids, check boxes, or any other screen controls that allow 
the student to view and manipulate his deliverables. The developer must also code logic that 
analyzes the student's work and provides feedback interactions. These interactions may take the 
form of text and/or multimedia feedback from simulated team members, conversations with 
simulated team members, or direct manipulations of the student's work by simulated team 
members. In parallel with these coding efforts, graphics, videos, and audio are being created for 
use in the application. Managing the development of these assets have their own complications. 

Risks in the build phase include misinterpretation of the designs. If the developer does not 
accurately understand the designer's intentions, the application will not function as desired. 
Also, coding these applications requires very skilled developers because the logic that analyzes 
the student's work and composes feedback is very complex. 
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Test Phase 

The Test Phase, as the name implies, is for testing the application. Testing is performed to verify 
the application in three ways: first that the application functions properly (functional testing), 
second that the students understand the interface and can navigate effectively (usability testing), 
5 and third that the learning objectives are met (cognition testing). Functional testing of the 
application can be carried out by the development team or by a dedicated test team. If the 
application fails to function properly, it is debugged, fixed, recompiled and retested until its 
operation is satisfactory. Usability and cognition testing can only be carried out by test students 
who are unfamiliar with the application. If usability is unsatisfactory, parts of the interface and 
10 or feedback logic may need to be redesigned, recoded, and retested. If the learning objectives 
are not met, large parts of the application may need to be removed and completely redeveloped 
from a different perspective. 

J The test phase is typically where most of the difficulties in the BusSim development cycle are 
P 1 5 encountered. The process of discovering and fixing functional, usability, and cognition problems 
m is a difficult process and not an exact science. 

|H For functional testing, testers operate the application, either by following a test script or by 
J ; acting spontaneously and documenting their actions as they go. When a problem or unexpected 
1*20 result is encountered, it too is documented. The application developer responsible for that part of 
the application then receives the documentation and attempts to duplicate the problem by 
repeating the tester's actions. When the problem is duplicated, the developer investigates further 
to find the cause and implement a fix. The developer once again repeats the tester's actions to 
verify that the fix solved the problem. Finally, all other test scripts must be rerun to verify that 
25 the fix did not have unintended consequences elsewhere in the application. 

This process has inherent difficulty. If the tester is inaccurate in recording his actions, or the 
developer is inaccurate in repeating them, then the problem may never be duplicated and the 
defect never found. Furthermore, the problem may be dependent on some condition in the 
30 tester's environment that is not readily observable or is not even related to the application. This 
process has proven to be tedious, time-consuming, and of limited reliability. 
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For usability testing, test students operate the application as it will be operated in production. 
Ideally, their progress is only impeded by their lack of mastery of the content. As they gain 
proficiency, they are able to complete the activities and move on. As is often the case, however, 
they are impeded by unclear instructions, a non-intuitive interface, or other usability 
5 shortcomings. When these difficulties are encountered, the facilitators document the problems 
and student comments on what is needed to improve usability. 

There are two major risks associated with usability testing. First, student action recording is not 
as rigorous because actual students are performing the testing, so functional problems that don't 
1 0 appear until now are difficult to reproduce. Second, resolutions to usability problems often 

involve significant modification to the application code and interface which requires repeating of 
portions of design, build, and test. 

J« For cognition testing, students are surveyed and/or tested to determine their level of 
€31 5 understanding of the material. If results indicate that the learning objectives are not being 
m adequately met, the design is reevaluated. Changes proposed to improve the cognition may 
include massive redesign and rebuilding. 

ci- 
s . Execution Phase 

¥> 20 The Execution Phase refers to the steady state operation of the completed application in its 
m production environment. For some clients, this involves phone support for students. Clients 
0 may also want the ability to track students' progress and control their progression through the 

course. Lastly, clients may want the ability to track issues so they may be considered for 

inclusion in course maintenance releases. 

25 

One of the key values of on-line courses is that they can be taken at a time, location, and pace 
that is convenient for the individual student. However, because students are not centrally 
located, support is not always readily available. For this reason it is often desirable to have 
phone support for students. 

30 

Clients may also desire to track students' progress, or control their advancement through the 
course. Under this strategy, after a student completes a section of the course, he will transfer his 
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progress data to a processing center either electronically or by physically mailing a disk. There it 
can be analyzed to verify that he completed all required work satisfactorily. One difficulty 
commonly associated with student tracking is isolating the student data for analysis. It can be 
unwieldy to transmit all the course data, so it is often imperative to isolate the minimum data 
5 required to perform the necessary analysis of the student's progress. 



A Delivery Framework for Business Simulation 

As discussed earlier, the traditional development process used to build BusSim solutions reflects 
more of a "one off philosophy, where development is done from scratch in a monolithic fashion, 
10 with little or no reuse from one application to the next. A better approach would be to focus on 
reducing the total effort required for development through reuse, which, in turn would decrease 
cost and development time. 



fl 



The first step in considering reuse as an option is the identification of common aspects of the 
©15 different BusSim applications that can be generalized to be useful in future applications. In 

i.j, 

m examination of the elements that make up these applications, three common aspects emerge as 
5f integral parts of each: 
IF] ■ Interface 
■ Analysis 
H20 ■ Interpretation 



Interface 

Every BusSim application must have a mechanism for interaction with the student. The degree 
of complexity of each interface may vary, from the high interactivity of a high-fidelity real-time 
25 simulation task, to the less complex information delivery requirements of a business case 

background information task. Regardless of how sophisticated the User Interface (UI), it is a 
vital piece of making the underlying simulation and feedback logic useful to the end user. 



Analysis 

30 Every BusSim application does analysis on the data that defines the current state of the 

simulation many times throughout the execution of the application. This analysis is done either 
to determine what is happening in the simulation, or to perform additional calculations on the 
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data which are then fed back into the simulation. For example, the analysis may be the 
recognition of any actions the student has taken on artifacts within the simulated environment 
(notebooks, number values, interviews conducted, etc.), or it may be the calculation of an ROI 
based on numbers the student has supplied. 

Interpretation 

Substantive, useful feedback is a critical piece of any BusSim application. It is the main 
mechanism to communicate if actions taken by the student are helping or hurting them meet their 
performance objectives. The interpretation piece of the set of proposed commonalties takes the 
results of any analysis performed and makes sense of it. It takes the non-biased view of the 
world that the Analysis portion delivers (i.e., "Demand is up 3%") and places some evaluative 
context around it (i.e., "Demand is below the expected 7%; you're in trouble!", or "Demand has 
exceeded projections of 1.5%; Great job!"). Figure 5 illustrates commonalties in accordance 
with a preferred embodiment. 

Common Features of Business Simulation Applications 

There are several approaches to capturing commonalties for reuse. Two of the more common 
approaches are framework-based and component-based. To help illustrate the differences 
between the two approaches, we will draw an analogy between building an application and 
building a house. One can construct a house from scratch, using the raw materials, 2x4s, nails, 
paint, concrete, etc. One can also construct an application from scratch, using the raw materials 
of new designs and new code. The effort involved in both undertakings can be reduced through 
framework-based and/or component-based reuse. 

Framework-Based Reuse 

Within the paradigm of framework-based reuse, a generic framework or architecture is 
constructed that contains commonalties. In the house analogy, one could purchase a 
prefabricated house framework consisting of floors, outside walls, bearing walls and a roof. The 
house can be customized by adding partition walls, wall-paper, woodwork, carpeting etc. 
Similarly, prefabricated application frameworks are available that contain baseline application 
structure and functionality. Individual applications are completed by adding specific 
functionality and customizing the look-and-feel. An example of a commonly used application 
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framework is Microsoft Foundation Classes. It is a framework for developing Windows 
applications using C++. MFC supplies the base functionality of a windowing application and the 
developer completes the application by adding functionality within the framework. 
Framework-based reuse is best suited for capturing template-like features, for example user 
interface management, procedural object behaviors, and any other features that may require 
specialization. 

Some benefits of using a framework include: 

■ Extensive functionality can be incorporated into a framework. In the house analogy, if I 
know I am going to build a whole neighborhood of three bedroom ranches, I can build the 
plumbing, wiring, and partition walls right into the framework, reducing the incremental effort 
required for each house. If I know I am going to build a large number of very similar 
applications, they will have more commonalties that can be included in the framework rather 
than built individually. 

■ Applications can override the framework-supplied functionality wherever appropriate. 

If a house framework came with pre-painted walls, the builder could just paint over them with 
preferred colors. Similarly, the object oriented principle of inheritance allows an application 
developer to override the behavior of the framework. 

Component-Based Reuse 

In the paradigm of component-based reuse, key functionality is encapsulated in a component. 
The component can then be reused in multiple applications. In the house analogy, components 
correspond to appliances such as dishwashers, refrigerators, microwaves, etc. 
Similarly, many application components with pre-packaged functionality are available from a 
variety of vendors. An example of a popular component is a Data Grid. It is a component that 
can be integrated into an application to deliver the capability of viewing columnar data in a 
spreadsheet-like grid. Component-based reuse is best suited for capturing black-box-like 
features, for example text processing, data manipulation, or any other features that do not require 
specialization. 

Some benefits of using components include: 
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• Several applications on the same computer can share a single component. This is not such 
a good fit with the analogy, but imagine if all the houses in a neighborhood could share the same 
dishwasher simultaneously. Each home would have to supply its own dishes, detergent, and 
water, but they could all wash dishes in parallel. In the application component world, this type 

5 of sharing is easily accomplished and results in reduced disk and memory requirements. 

■ Components tend to be less platform and tool dependent A microwave can be used in 
virtually any house, whether it's framework is steel or wood, and regardless of whether it was 
customized for building mansions or shacks. You can put a high-end microwave in a low-end 
house and vice-versa. You can even have multiple different microwaves in your house. 

1 0 Component technologies such as CORBA, COM, and Java Beans make this kind of flexibility 
commonplace in application development. 



The Solution: A Combined Approach 

Often, the best answer to achieving reuse is through a combination of framework-based and 
component-based techniques. A framework-based approach for building BusSim applications is 
appropriate for developing the user interface, handling user and system events, starting and 
stopping the application, and other application-specific and delivery platform-specific functions. 
A component-based approach is appropriate for black-box functionality. That is, functionality 
that can be used as-is with no specialization required. 

In creating architectures to support BusSim application development, it is imperative that any 
assets remain as flexible and extensible as possible or reusability may be diminished. Therefore, 
we chose to implement the unique aspects of BusSim applications using a component approach 
rather than a framework approach. This decision is further supported by the following 
25 observations. 

■ An application can only be based on one framework. Using the house analogy, if you like 
the first floor of one framework and the second floor of another, it is difficult or impossible to 
integrate the features of the two. Or, it is so costly as to erase the benefit of using a framework 
in the first place. Likewise with application frameworks. You can only use one framework 
30 when building an application You can't mix and match features from multiple frameworks, so 
any framework that we developed would have to compete against existing and future 
frameworks. With components, however, you can mix and match from multiple vendors. 
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■ Components are less platform and development tool dependent, leaving more options 
open for development teams. An appliance like a dishwasher is not restricted for use in a 
particular type of house. Similarly, component technologies exist that are independent of 
platform and development tool. For example ActiveX can be used in almost every development 
environment for Windows and Java Beans components can be used on a wide variety of 
platforms. 

■ Frameworks become obsolete more quickly. Rapid emergence and evolution of technology 
has introduced a wealth of new feature requirements into application development. Frameworks 
that do not include the most current features become obsolete quickly. Components typically 
address a more focused feature set and are not as impacted by technology advances outside their 
core functionality areas. 

Based on these observations, we believe a combined framework/component approach is optimal 
for achieving reuse. Figure 6 illustrates a development architecture approach in accordance with 
a preferred embodiment. 

Delivery Framework for Business Simulation 

This diagram illustrates an ideal solution where components are combined with an Application 
Framework and an Application Architecture to achieve maximum reuse and minimum custom 
development effort. The Application Architecture is added to provide communication support 
between the application interface and the components, and between the components. This 
solution has the following features: 

■ The components (identified by the icons) encapsulate key BusSim functionality. 

■ The Application Architecture provides the glue that allows application-to-component and 
component-to-component communication. 

■ The Application Framework provides structure and base functionality that can be customized 
for different interaction styles. 

■ Only the application interface must be custom developed. 

The next section discusses each of these components in further detail. 
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The Business Simulation Toolset 

We have clearly defined why a combined component/framework approach is the best solution 
for delivering high-quality BusSim solutions at a lower cost. Given that there are a number of 
third party frameworks already on the market that provide delivery capability for a wide variety 

5 of platforms, the TEL project is focused on defining and developing a set of components that 
provide unique services for the development and delivery of BusSim solutions. These 
components along with a set of design and test workbenches are the tools used by instructional 
designers to support activities in the four phases of BusSim development. We call this suite of 
tools the Business Simulation Toolset. Following is a description of each of the components and 

1 0 workbenches of the toolset. 



Components 

A Component can be thought of as a black box that encapsulates the behavior and data necessary 
to support a related set of services. It exposes these services to the outside world through 
Q15 published interfaces. The published interface of a component allows you to understand what it 
M does through the services it offers, but not how it does it. The complexity of its implementation 

PJ is hidden from the user. The following are the key components of the BusSim Toolset. 

m 

m ■ Domain Component - provides services for modeling the state of a simulation 

f ■ Profiling Component - provides services for rule-based evaluating the state of a simulation 

%h 20 * Transformation Component - provides services for manipulating the state of a simulation 

W « Remediation Component - provides services for the rule-based delivering of feedback to the 

19 student 

Domain Component 

25 The Domain Model component is the central component of the suite that facilitates 

communication of context data across the application and the other components. It is a modeling 
tool that can use industry-standard database such as Informix, Oracle, or Sybase to store its data. 
A domain model is a representation of the objects in a simulation. The objects are such pseudo 
tangible things as a lever the student can pull, a form or notepad the student fills out, a character 

30 the student interacts with in a simulated meeting, etc. They can also be abstract objects such as 
the ROI for a particular investment, the number of times the student asked a particular question, 
etc. These objects are called entities. Some example entities include: 
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■ Vehicles, operators and incidents in an insurance domain 

■ Journal entries, cash flow statements and balance sheets in a financial accounting domain 

■ Consumers and purchases in a marketing domain 

5 An entity can also contain other entities. For example, a personal bank account entity might 
contain an entity that represents a savings account. Every entity has a set of properties where 
each property in some way describes the entity. The set of properties owned by an entity, in 
essence, define the entity. Some example properties include: 

■ An incident entity on an insurance application owns properties such as "Occurrence Date", 
1 0 "Incident Type Code", etc. 

■ A journal entry owns properties such as "Credit Account", "Debit Account", and "Amount" 

■ A revolving credit account entity on a mortgage application owns properties such as 
"Outstanding Balance", "Available Limit", etc. Figure 7 illustrates a small segment of a domain 
model for claims handlers in the auto insurance industry in accordance with a preferred 

£515 embodiment. 
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Example Domain Model 

The domain model is created by the instructional designer in a visual editing design tool called 
the Knowledge Workbench. The designer creates the objects of the domain model using generic 
1.20 entities and properties; that is, not having specific values associated with the entities and 
properties. 



At runtime, an application's domain model is instantiated so that every entity and property is 
given a particular value that makes it unique. The result of a domain model instantiation is 
25 called the domain. The values of a domain's entities and properties can change throughout the 
course of the simulation based on student actions and updates from other components. Figure 8 
illustrates an instantiated domain model in accordance with a preferred embodiment. 

Example Domain 

30 Creating a domain model in data rather than in code facilitates reuse of the components in 
multiple applications in multiple domains without code changes. For example, a typical 
application in the Financial Services domain would have to define classes in code such as 
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'Customer', 'Account', etc. An Insurance Domain application might have classes such as 
'Customer', 'Incident', 'Prior Policy', etc. To be able to perform analysis on any of these 
classes, the analysis logic must be coded to recognize the classes. This requires all logic to be 
custom-coded for every application; an effort-intensive undertaking that demands a high degree 
5 of technical skill. 

By modeling the domain in data using generic objects, we can build standard generic analysis 
capability that can be applied to the domain. This allows implementation of analysis logic with 
much less effort by people with a low degree of technical skill. Functional experts can create the 
10 objects of the domain and apply various types of analysis from a pallet. All of this is 

accomplished in a visual development environment that supports the designer with visual 
feedback and only allows valid designs to be created. 

Profiling Component 

0 1 5 In the simplest terms, the purpose of the Profiling Component is to analyze the current state of a 
m domain and identify specific things that are true about that domain. This information is then 

passed to the Remediation Component which provides feedback to the student. The Profiling 
f 1 Component analyzes the domain by asking questions about the domain's state, akin to an 
I s investigator asking questions about a case. The questions that the Profiler asks are called 
h h 20 profiles. For example, suppose there is a task about building a campfire and the student has just 
fi thrown a match on a pile of wood, but the fire didn't start. In order to give useful feedback to the 
0 student, a tutor would need to know things like: was the match lit?, was the wood wet?, was 

there kindling in the pile?, etc. These questions would be among the profiles that the Profiling 

Component would use to analyze the domain. The results of the analysis would then be passed 
25 off to the Remediation Component which would use this information to provide specific 

feedback to the student. 

Specifically, a profile is a set of criteria that is matched against the domain. The purpose of a 
profile is to check whether the criteria defined by the profile is met in the domain. Using a 
30 visual editing tool, instructional designers create profiles to identify those things that are 

important to know about the domain for a given task. During execution of a BusSim application 
at the point that feedback is requested either by the student or pro-actively by the application, the 
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set of profiles associated with the current task are evaluated to determine which ones are true. 
Example profiles include: 

■ Good productions strategy but wrong Break-Even Formula 

■ Good driving record and low claims history 

5 ■ Correct Cash Flow Analysis but poor Return on Investment (ROI) 

A profile is composed of two types of structures: characteristics and collective characteristics. 
A characteristic is a conditional (the z/half of a rule) that identifies a subset of the domain that is 
important for determining what feedback to deliver to the student. Example characteristics 
10 include: 

■ Wrong debit account in transaction 1 

■ Perfect cost classification 

■ At Least 1 DUI in the last 3 years 

■ More than $4000 in claims in the last 2 years 



CP 1 5 ■ More than two at-fault accidents in 5 years 

W A characteristic's conditional uses one or more atomics as the operands to identify the subset of 

PI 

m the domain that defines the characteristic. An atomic only makes reference to a single property 

f . of a single entity in the domain; thus the term atomic. Example atomics include: 

\*20 ■ The number of Dill's >= 1 

P - ROI>10% 

p ■ Income between $75,000 and $110,000 

A collective characteristic is a conditional that uses multiple characteristics and/or other 
25 collective characteristics as its operands. Collective characteristics allow instructional designers 
to build richer expressions (i.e., ask more complex questions). Example collective characteristics 
include: 

■ Bad Household driving record 
« Good Credit Rating 

30 ■ Marginal Credit Rating 

■ Problems with Cash for Expense transactions 
* Problems with Sources and uses of cash 
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Once created, designers are able to reuse these elements within multiple expressions, which 
significantly eases the burden of creating additional profiles. When building a profile from its 
elements, atomics can be used by multiple characteristics, characteristics can be used by multiple 
collective characteristics and profiles, and collective characteristics can be used by multiple 
collective characteristics and profiles. 

Figure 9 illustrates an insurance underwriting profile in accordance with a preferred 
embodiment. 



Example Profile for Insurance Underwriting 



Transformation Component 

Whereas the Profiling Component asks questions about the domain, the Transformation 
15 Component performs calculations on the domain and feeds the results back into the domain for 
yj further analysis by the Profiling Component. This facilitates the modeling of complex business 
systems that would otherwise be very difficult to implement as part of the application. Within 
the Analysis phase of the Interface/ Analysis/Interpretation execution flow, the Transformation 
ij\ Component actually acts on the domain before the Profiling Component does its analysis. 
W 5 20 The Transformation Component acts as a shell that wraps one or more data modeling 
m components for the purpose of integrating these components into a BusSim application. The 
W Transformation Component facilitates the transfer of specific data from the domain to the data 

modeling component (inputs) for calculations to be performed on the data, as well as the transfer 
of the results of the calculations from the data modeling component back to the domain 
25 (outputs). Figure 10 illustrates a transformation component in accordance with a preferred 
embodiment. 

The data modeling components could be third party modeling environments such as spreadsheet- 
based modeling (e.g., Excel, Formulal) or discrete time-based simulation modeling (e.g., 
30 PowerSim, VenSim). The components could also be custom built in C++, VB, Access, or any 
tool that is ODBC compliant to provide unique modeling environments. Using the 
Transformation Component to wrap a third party spreadsheet component provides an easy way 
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of integrating into an application spreadsheet-based data analysis, created by such tools as Excel. 
The Transformation Component provides a shell for the spreadsheet so that it can look into the 
domain, pull out values needed as inputs, performs its calculations, and post outputs back to the 
domain. 

5 For example, if the financial statements of a company are stored in the domain, the domain 

would hold the baseline data like how much cash the company has, what its assets and liabilities 
are, etc. The Transformation Component would be able to look at the data and calculate 
additional values like cash flow ratios, ROI or NPV of investments, or any other calculations to 
quantitatively analyze the financial health of the company. Depending on their complexity, these 
10 calculations could be performed by pre-existing spreadsheets that a client has already spent 
considerable time developing. 

Remediation Component 

The Remediation Component is an expert system that facilitates integration of intelligent 



Q 15 feedback into BusSim applications. It has the following features: 

O 

|| ■ Ability to compose high quality text feedback. 

■ Ability to compose multimedia feedback that includes video and/or audio. 

Syl ■ Ability to include reference material in feedback such as Authorware pages or Web Pages. 

j\ ■ Ability to actively manipulate the users deliverables to highlight or even fix users' errors. 

W 20 "A proven remediation theory embedded in its feedback composition algorithm. 

m ■ Allows integration of digital assets into the Remediation of a training or IPS application. 



The Remediation model consists of three primary objects: 

■ Concepts 

25 ■ Coach Topics 

■ Coach Items 

Concepts are objects that represent real-world concepts that the user will be faced with in the 
interface. Concepts can be broken into sub-concepts, creating a hierarchical tree of concepts. 
30 This tree can be arbitrarily deep and wide to support rich concept modeling. Concepts can also 
own an arbitrary number of Coach Topics. 
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Coach Topics are objects that represent a discussion topic that may be appropriate for a concept. 
Coach Topics can own an arbitrary number of Coach Items. 

Coach Items are items of feedback that may include text, audio, video, URL's, or updates to the 
Domain Model. Coach Items are owned by Coach Topics and are assembled by the Remediation 
5 Component algorithm. 

Details of the Remediation Component algorithm for feedback is discussed in The Intelligent 
Coaching Agent Tool whitepaper and can be found on the Knowledge Exchange at the 
Technology Enabled Learning ETA Home Page. 

10 Workbenches 

The BusSim Toolset also includes a set of workbenches that are used by instructional designers 
to design and build BusSim applications. A workbench is a tool that facilitates visual editing or 
testing of the data that the BusSim Components use for determining an application's run-time 

■!!* behavior. The BusSim Toolset includes the following workbenches: 

J9 1 5 Knowledge Workbench 

if' 5 

The Knowledge Workbench is a tool for the creation of domain, analysis and feedback data that 
is used by the BusSim Components. It has the following features: 
m ■ Allows the designer to 'paint' knowledge in a drag-and-drop interface, 
f ■ Knowledge is represented visually for easy communication among designers. 

1^20 ■ The interface is intelligent, allowing designers to only paint valid interactions. 

S ■ Designer's Task creations are stored in a central repository. 

u I 

|3 ■ The workbench supports check-in / check-out for exclusive editing of a task. 

■ Supports LAN-based or untethered editing. 

■ Automatically generates documentation of the designs. 

25 ■ Generates the data files that drive the behavior of the components. 

Simulated Student Test Workbench 

The Simulated Student Test Workbench is a tool for the creation of data that simulates student's 
actions for testing BusSim Component behaviors. It has the following features: 
30 ■ The Test Bench generates a simulated application interface based on the Domain Model. 

■ The designer manipulates the objects in the Domain Model to simulate student activity. 
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■ The designer can invoke the components to experience the interactions the student will 
experience in production. 

■ The designer can fully test the interaction behavior prior to development of the application 
interface. 

Regression Test Workbench 

The Regression Test Workbench is a tool for replaying and testing of student sessions to aid 
debugging. It has the following features: 

■ Each student submission can be individually replayed through the components. 

■ An arbitrary number of student submissions from the same session can be replayed in 
succession. 

■ Entire student sessions can be replayed in batch instantly. 

■ The interaction results of the student are juxtaposed with the results of the regression test for 
comparison. 

Development Cycle Activities 
Design Phase 

The design phase of a BusSim application is streamlined by the use of the Knowledge 
Workbench. The Knowledge Workbench is a visual editor for configuring the objects of the 
component engines to control their runtime behavior. The components are based on proven 
algorithms that capture and implement best practices and provide a conceptual framework and 
methodology for instructional design. 

In conceptual design, the workbench allows the designer to paint a model of the hierarchy of 
Concepts that the student will need to master in the activity. This helps the designer organize the 
content in a logical way. The visual representation of the Concepts helps to communicate ideas 
to other designers for review. The consistent look and feel of the workbench also contributes to 
a streamlined Quality Assurance process. In addition, standard documentation can be 
automatically generated for the entire design. 

As the design phase progresses, the designer adds more detail to the design of the Concept 
hierarchy by painting in Coach Topics that the student may need feedback on. The designer can 
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associate multiple feedback topics with each Concept, The designer also characterizes each topic 
as being Praise, Polish, Focus, Redirect or one of several other types of feedback that are 
consistent with a proven remediation methodology. The designer can then fill each topic with 
text, video war stories, Web page links, Authorware links, or any other media object that can be 
delivered to the student as part of the feedback topic. 

As the designer's thoughts for the interface become clearer, she can begin to model the domain 
objects in the Knowledge Workbench. The student's world is constructed using objects in the 
Domain Model 

The designer again uses the Knowledge Workbench to configure objects in the Transformation 
Component. The Transformation Component is used to perform calculations or other analysis of 
the student's domain. Lastly, the designer uses the workbench to configure objects in the 
Profiling Component. The Profiling Component examines the student's domain, looking for 
conditions that indicate what feedback topics are appropriate for delivery. 
More importantly, the Student Simulator Test Workbench allows the designer to exercise the 
designs. It allows the designer to manipulate the domain as if she were a student. The designer 
can interact with the simulated interface and invoke the component engines to see the feedback 
that the student would receive. This capability can also be utilized in a usability test such as a 
Conference Room Pilot. As the test student interacts with screen mock-ups, a facilitator can 
mimic his actions in the interface simulator and tell the student what the actual feedback will be. 
This results in much more rigorous testing prior to application construction. A big payoff is 
realized downstream in the form of reduced redesign after usability and cognition testing. 

Throughout all these steps in the initial design, the workbench supports the design process by 
allowing the designer great flexibility within the framework of a proven methodology. This 
allows experienced users to design rich, realistic interactions, and inexperienced users to become 
competent in a shorter time by learning from the best practices embedded in the workbench. 
This greatly diminishes the 'blue sky' design problem. Also, since the designs can be tested 
prior to application construction, there is reduced rework after testing. Lastly, the visual 
knowledge representation enhances communication within the design team and greatly 
streamlines the QA process. 
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Build Phase 

It is very clear how the tools support the Build Phase, The designs that the designer painted in 
the Knowledge Workbench drive the components at runtime. The application developer no 
5 longer has to write code that analyzes the student's work and provides feedback. The developer 
only has to build the interface and logic to report any student actions to the domain model. The 
components do the rest. What used to be the most difficult part of the build phase has been 
eliminated! 

10 There is no chance for a developer to misinterpret the feedback designs because she never has to 
interpret them. In fact, the developer doesn't even have to know anything about the feedback 
behavior as long as she is familiar with the domain model. This also means the skill level 
required to develop the application can be greatly reduced. It's not hard to teach someone how 

JjJ to paint a screen in Visual Basic or Delphi and call API functions to notify the Domain Model of 

til 

C5 1 5 student actions. 

f i 

fU In addition to the economies gained by the components, it is possible to use templates to further 

IT? K 
'Z7, ? 

fjl streamline design and development of commonly used interactions. We have created templates 

f t for several common interactions. For example, Journalizing of Transactions is an interaction that 

|»*20 has appeared in several applications. We have built application and Knowledge Workbench 

templates for Journalization. All one must do to create a new Journalize task is to add graphics 

O for new Transactions and fill in new data into placeholders in the Knowledge Workbench. 

Test Phase 

25 The toolset greatly reduces effort during functionality testing. The key driver of the effort 
reduction is that the components can automatically track the actions of the tester without the 
need to add code support in the application. Whenever the tester takes an action in the interface, 
it is reported to the domain model. From there it can be tracked in a database. Testers no longer 
need to write down their actions for use in debugging; they are automatically written to disk. 

30 There is also a feature for attaching comments to a tester's actions. When unexpected behavior 
is encountered, the tester can hit a control key sequence that pops up a dialog to record a 
description of the errant behavior. 
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Of far greater impact is the ability to replay the tester's actions automatically through the 
Regression Test Workbench. The designer does not need to spend hours trying to duplicate the 
error. She simply loads the tester's session into the Regression Test Workbench and replays it. 
In seconds the error is replicated and can be located and fixed using a variety of debugging 
utilities. After changes have been made, one more pass through the Regression Test Workbench 
verifies the fix. 

The major difficulties of usability and cognition testing are also addressed by the toolset. First, 
since student tracking is no longer a manual activity, the precision of functional testing can also 
be applied to usability and cognition testing. Second, because of the increased rigor in the 
Conference Room Pilot, the risk of significant rework is greatly reduced. 

Execution Phase 

During the Execution Phase, the components are deployed to the student's platform. They 
provide simulated team member and feedback functionality with sub-second response time and 
error-free operation. If the client desires it, student tracking mechanisms can be deployed at 
runtime for evaluation and administration of students. This also enables the isolation of any 
defects that may have made it to production. 

Scenarios for Using the Business Simulation Toolset 

A good way to gain a better appreciation for how the BusSim Toolset can vastly improve the 
BusSim development effort is to walk through scenarios of how the tools would be used 
throughout the development lifecycle of a particular task in a BusSim application. For this 
purpose, we'll assume that the goal of the student in a specific task is to journalize invoice 
transactions, and that this task is within the broader context of learning the fundamentals of 
financial accounting. A cursory description of the task from the student's perspective will help 
set the context for the scenarios. Following the description are five scenarios which describe 
various activities in the development of this task. The figure below shows a screen shot of the 
task interface. 
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Figure 11 illustrates the use of a toolbar to navigate and access application level features in 
accordance with a preferred embodiment. A student uses a toolbar to navigate and also to access 
some of the application-level features of the application. The toolbar is the inverted L-shaped 
object across the top and left of the interface. The top section of the toolbar allows the user to 
5 navigate to tasks within the current activity. The left section of the toolbar allows the student to 
access other features of the application, including feedback. The student can have his 
deliverables analyzed and receive feedback by clicking on the Team button. 
In this task, the student must journalize twenty-two invoices and other source documents to 
record the flow of budget dollars between internal accounts. (Note: "Journalizing", or 
10 "Journalization", is the process of recording journal entries in a general ledger from invoices or 
other source documents during an accounting period. The process entails creating debit and 
balancing credit entries for each document. At the completion of this process, the general ledger 
records are used to create a trial balance and subsequent financial reports.) 

U 

£315 In accordance with a preferred embodiment, an Intelligent Coaching Agent Tool (ICAT) was 
Jfi developed to standardize and simplify the creation and delivery of feedback in a highly complex 

and open-ended environment. Feedback from a coach or tutor is instrumental in guiding the 
m learner through an application. Moreover, by diagnosing trouble areas and recommending 
^ specific actions based on predicted student understanding of the domain student comprehension 
Jf*20 of key concepts is increased. By writing rules and feedback that correspond to a proven 
|| feedback strategy, consistent feedback is delivered throughout the application, regardless of the 
■0 interaction type or of the specific designer/developer creating the feedback. The ICAT is 

packaged with a user-friendly workbench, so that it may be reused to increase productivity on 

projects requiring a similar rule-based data engine and repository. 

25 

Definition of ICAT In Accordance with a Preferred Embodiment 

The Intelligent Coaching Agent Tool (ICAT) is a suite of tools-a database and a Dynamic Link 
Library (DLL) run-time engine — used by designers to create and execute just-in-time feedback 
of Goal Based training. Designers write feedback and rules in the development tools. Once the 
30 feedback is set, the run-time engine monitors user actions, fires rules and composes feedback 
which describes the business deliverable. 
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I. The ICAT Remediation Model 

The remediation model used within ICAT dynamically composes the most appropriate feedback 
to deliver to a student based on student's previous responses. The ICAT model is based on a 
theory of feedback which has been proven effective by pilot results and informal interviews. The 
model is embodied in the object model and algorithms of the ICAT. Because the model is built 
into the tools, all feedback created with the tool will conform to the model. 

H. The Role of ICAT in Student Training 

The ICAT plays two roles in student training. First, the ICAT is a teaching system, helping 
students to fully comprehend and apply information. Second, ICAT is a gatekeeper, ensuring 
that each student has mastered the material before moving on to additional information. 

EI. The Functional Definition of the ICAT 

The ICAT is a self contained module, separate from the application. Separating the ICAT from 
the application allows other projects to use the ICAT and allows designers to test feedback 
before the application is complete. The ICAT Module is built on six processes which allow a 
student to interact effectively with the interface to compose and deliver the appropriate feedback 
for a student's mistakes. 

IV. The ICAT Development Methodology for Creating Feedback 

The ICAT development methodology is a seven step methodology for creating feedback. The 
methodology contains specific steps, general guidelines and lessons learned from the field. 
Using the methodology increases the effectiveness of the feedback to meet the educational 
requirements of the course. 

V. Components 

The processes each contain a knowledge model and some contain algorithms. Each process has 
specific knowledge architected into its design to enhance remediation and teaching. 

VI. Testing Utilities, Reports and Methodology 

There is a suite of testing tools for the ICAT. These tools allow designers and developers test all 
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of their feedback and rules. In addition, the utilities let designers capture real time activities of 
students as they go through the course. 

Expert Remediation Model Within the Tools 

The tools and run-time engine in accordance with a preferred embodiment include expert 
knowledge of remediation. These objects include logic that analyzes a student's work to identify 
problem areas and deliver focused feedback. The designers need only instantiate the objects to 
put the tools to work. Embodying expert knowledge in the tools and engine ensures that each 
section of a course has the same effective feedback structure in place. 

Any project which is creating a Goal-Based Scenario (GBS) business simulation or an 
Integrated Performance Support (IPS) system to help users understand and create business 
deliverables can profit from technology in accordance with a preferred embodiment. A GBS 
allows students to learn in a comprehensive simulated environment. Students work in a 
simulated environment to accomplish real world tasks, and when they make mistakes, 
remediation is provided to help identify and correct the mistakes. The hands-on experience of 
the simulated environment and the timely remediation account for the high retention rate from 
subjects presented utilizing a system in accordance with a preferred embodiment. A system in 
accordance with a preferred embodiment can be used in conjunction with an EPS to help users 
develop deliverables. If a customer service representative (CSR) is completing a form while 
conducting a phone conversation, the ICAT can be used to observe how the task is completed to 
provide a live analysis of mistakes. 

A file structure in accordance with a preferred embodiment provides a standard system 
environment for all applications in accordance with a preferred embodiment. A development 
directory holds a plurality of sub-directories. The content in the documentation directory is part 
of a separate installation from the architecture. This is due to the size of the documentation 
directory. It does not require any support files, thus it may be placed on a LAN or on individual 
computers. 

When the architecture is installed in accordance with a preferred embodiment, the development 
directory has an _Arch, Tools, Utilities, Documentation, QED, and XDefault development 
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directory. Each folder has its own directory structure that is inter-linked with the other 
directories. This structure must be maintained to assure consistency and compatibility between 
projects to clarify project differences, and architecture updates. 

5 The _Arch directory stores many of the most common parts of the system architecture. These 
files generally do not change and can be reused in any area of the project. If there is common 
visual basic code for applications that will continuously be used in other applications, the files 
will be housed in a folder in this directory. 

10 The sub-directories in the _Arch directory are broken into certain objects of the main project. 
Object in this case refers to parts of a project that are commonly referred to within the project. 
For example, modules and classes are defined here, and the directory is analogous to a library of 
functions, APIs, etc. . . that do not change. For example the IcaObj directory stores code for the 

E~ Intelligent Coaching Agent (ICA). The InBoxObj directory stores code for the InBox part of the 

%ij 

015 project and so on. The file structure uses some primary object references as file directories. For 

Q 

ffi example, the IcaObj directory is a component that contains primary objects for the ICA such as 

PJ functional forms, modules and classes. 

m 

U The BrowserObj directory contains modules, classes and forms related to the browser 

Li. 

|^20 functionality in the architecture. 

The HTMLGIossary directory contains code that is used for the HTML reference and glossary 
component of the architecture. 

25 The IcaObj directory contains ICA functional code to be used in an application. This code is 
instantiated and enhanced in accordance with a preferred embodiment. 

The InBoxObj directory contains code pertaining to the inbox functionality used within the 
architecture. Specifically, there are two major components in this architecture directory. There 
30 is a new .ocx control that was created to provide functionality for an inbox in the application. 
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There is also code that provides support for a legacy inbox application. The PracticeObj 
directory contains code for the topics component of the architecture. The topics component can 
be implemented with the HTMLGlossary component as well. 

The QmediaObj directory contains the components that are media related. An example is the 
QVIDctrLcls. The QVEDctrl is the code that creates the links between QVID files in an 
application and the system in accordance with a preferred embodiment. 

The SimObj directory contains the Simulation Engine, a component of the application that 
notifies the tutor of inputs and outputs using a spreadsheet to facilitate communication. 

The StaticObj directory holds any component that the application will use statically from the 
rest of the application. For example, the login form is kept in this folder and is used as a static 
object in accordance with a preferred embodiment. 

The SysDynObj directory contains the code that allows the Systems Dynamics Engine 
(Powersim) to pass values to the Simulation Engine and return the values to the tutor. 

The VBObj directory contains common Visual Basic objects used in applications. For example 
the NowWhat, Visual Basic Reference forms, and specific message box components are stored 
in this folder. 

The _TooIs directory contains two main directories. They represent the two most used tools in 
accordance with a preferred embodiment. The two directories provide the code for the tools 
themselves. The reason for providing the code for these tools is to allow a developer to enhance 
certain parts of the tools to extend their ability. This is important for the current project 
development and also for the growth of the tools. 
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The Icautils directory contains a data, database, default, graphics, icadoc, and testdata 

directory. The purpose of all of these directories is to provide a secondary working directory for 
a developer to keep their testing environment of enhanced Icautils applications separate from the 
project application. It is built as a testbed for the tool only. No application specific work should 
be done here. The purpose of each of these directories will be explained in more depth in the 
project directory section. The TestData folder is unique to the _Tools/ICAUtils directory. It 
contains test data for the regression bench among others components in ICAUtils. 

Utilities 

The Utilities directory holds the available utilities that a Business Simulation project requires for 
optimal results. This is a repository for code and executable utilities that developers and 
designers may utilize and enhance in accordance with a preferred embodiment. Most of the 
utilities are small applications or tools that can be used in the production of simulations which 
comprise an executable and code to go with it for any enhancements or changes to the utility. If 
new utilities are created on a project or existing utilities are enhanced, it is important to notify 
the managers or developers in charge of keeping track of the Business Simulation assets. Any 
enhancements, changes or additions to the Business Simulation technology assets are important 
for future and existing projects. 

Documentation 

A Documentation directory is used to store pertinent documentation. The documentation 
directory is structured as follows. Most of the directories are labeled after the specific 
information held within them. The following is a list of all the documentation directories and a 
description of what is contain in each. 

Ref Website - This directory contains The Business Simulation Reference website, which is a 
general reference for many things. If the website has not been set up for users on a LAN or 
website, all you need to do is go into the root directory of website and double click on index.htm. 
This is the main page for the site. 
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Components - This directory contains any documentation on classes and modules that are used 
in the archtecture. For example there are documents here on the ICAMeeting class, the Inbox 
class etc. 

Database - This directory contains any documents describing the databases that are included 
and used in the Architecture. For example the ICAObj overview doc contains a description of 
the model and each element in the database. 

HTML Component - This directory contains relevant documentation about the HTML part of 
the architecture. 

Process Models - This directory should contain the documents that describe the process of the 
application or related information. 

Reference App - This directory contains documents with descriptions and views of the reference 
app. (QED) for explanation and documentation. Testing conditions are stored in the Testing 
directory. 

Standards&Templates - This directory contains any type of architecture relevant coding 
standard documents or templates that a developer is required to follow. 

UserGuides- This directory has 6 sub-directories. Each one of these sub-directories contains 
user guides for a given tool or component in accordance with a preferred embodiment which 
include user guides for the architecture, the Tutor Suite, ICA Utilities, the simulation Engine and 
the System Dynamics Engine. There is also a directory for other documentation that contains 
user guides for any other tools or code like third party controls etc. 

WorkFlows - This directory contains the WF_Develop.doc which includes the workflow 
documentation for an application. 

Project Directory 

The sample project directory, QED has the same structure that a real project would be designed 
after. The QED directory has all custom architecture code, databases, spreadsheets, and any 
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other application specific files stored in it. The QED project directory stores a Design and 
SrcVB directory. The Design directory contains all relevant files for a designer. The SrcVB 
directory is used for a developer. 

5 The root directory of the Design and SrcVB directory contain a few important files to note. Both 
have two .rtf files, a few log files and an .ini file. The .rtf files are the feedback that is output 
from the tutor, the logs are also output from the tutor and the .ini file is for ICAUtils 
initialization. The design directory has three subdirectories that contain a data directory, which 
stores .xls files, sim models, and any other important data like html and video. It also has a 
10 database directory that holds any relevant databases for development and application use. The 
last directory is the icadoc directory which includes all .tut files or .ica files, which are both 
created with the tutor. 

J 

Q The SrcVB directory stores all of the directories previously described. The reason for 



SSI 5 duplicating the data and database directories is to assure that a developer does not interfere with 
f)j the designer's files. The developer tends to not do as much design work and can easily corrupt 
files. This duplication of directories provides a safer environment for the developer to test in. 
As was mentioned above, the developer tends to have a lot more to do with the application build 



ll than the design so there needs to be more content in the SrcVB directory. The SrcVB directory 
jkfj 20 also contains an .exe and .vbp file which are created in a developers visual basic application. 

0? R 

The following are directories found in the SrcVB directory that are not found in the Design 
directory followed by a short definition: 

25 The CustomArch directory contains any application specific architecture. Look in the QED 
folder for an example. 

The CustomDistribution directory contains any files that need to be distributed with the 
application. 



The Default directory contains any backup files that might need to be copied and reused later. 
Some files occasionally are corrupted and need to be replaced. 
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The Fonts directory contains application specific font libraries. 

The Graphics directory contains any relevant graphics for the application. 

The Help directory contains all files for a help reference layer in the application. This can be 
implemented in many ways but most commonly in an HTML form. 

The Saved directory is for saved information that is produced by the application. This can be 
used for saving student information or saving temporary information for the application steps. 

The StudentData directory is for storing any relevant student data, lists of students, their 
personal information or any relevant student data that needs to be saved. 

XDefauIt Development: 

The XDefauIt Development environment is used to provide a shell for any new project. A 
developer would rename this directory as an acronym of the project. QED is the default for the 
installation sample application. The XDefauIt development directory is a shell and serves as a 
building block for a startup project. A good idea is to use the QED sample application and build 
the XDefauIt Development project with the sample code in QED. 

Shared Development 

The last directory to be mentioned is the shared development directory which is placed on a 
LAN or central network area and is shared by all designers and developers of a project to assure 
that files in the project are up to date, managed properly and appropriately synchronized. There 
are many databases and files that will be shared in accordance with a preferred embodiment. 
These files need to be shared and have a location that someone can edit without having to worry 
about merging files later. A source control program is used to restrict access to a file to one 
application at a time. 
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The ICAT Model of Remediation 

The ICAT has a model of remediation architected into the system in accordance with a preferred 
embodiment. Feedback should help students complete tasks and learn the underlying concepts. 
To achieve this goal, the ICAT reviews student's work with the following objectives in mind. 

5 

Identify student misconceptions 

Identifying that a student does not understand a topic and then clearly explaining it is the goal of 
human and computer tutors alike. Human tutors, however, have many more clues-including 
facial expressions and body language-to help them identify student misconceptions. The 
10 computer tutor is much more limited and can only view the outputs— such as documents and 

reports-the student produces. If a computer tutor is looking for a misunderstanding about debits 
and credits, the computer analyzes all the mistakes a student made concerning debits and credits 
.y and tries to identify what misunderstanding would account for this pattern of mistakes. 

•L J 

ip 1 5 Identify what students should fix 

If the coach cannot diagnose a student's misconception, or cannot do it with 100% accuracy, the 
81 coach must at least tell the student what he did wrong so that he can correct it. If at all possible, 
I the coach should identify groups or types of problems the student is making so that the student 

f * can generalize the solution and answer. 

Hi?! 

*| Prompt students to reflect on mistakes 

j?* When identifying problems, the tutor needs to prompt the student to reflect on a problem and 
start to point the student towards the answer. The tutor should not tell the student the answer, 
but instead should attempt to provide an appropriate answer or give the student a question to 
25 think about. 

Reinforce correct concepts and ideas 

Once a student has gotten the correct answer, it is important to reinforce the learning. Students 
may feel uncertain about their understanding even after he has gotten the answer correct. To 
30 reinforce the student's understanding of the concept and provide a confidence boost, the tutor 
should walk the student through the answer so that it is completely understood. These goals are 
not just the goals of a computer tutor, but they are the goals of a human tutor as well. All tutors 
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must look at a student's work to help identify and correct errors as well as learn the material. 
One of the most difficult tasks facing a tutor is the difficult task of balancing the appropriate 
amount of assistance provided the student to complete the task with the requirement to help the 
student learn the material. 

Model of Feedback 

A preferred embodiment utilizes feedback to address the balancing task. The theory is centered 
on the idea of severity. Severe errors require severe feedback while mild errors require mild 
feedback. If a student writes a paper on the wrong subject, a human tutor will spend little time 
reviewing the paper, but instead, identify it as a serious mistake and ask the student to rewrite 
the paper. If the student simply misses one paragraph of the argument, then the tutor will focus 
the student on that paragraph. Finally, if the paper is correct except for a couple of spelling 
mistakes, the tutor will point out the specific mistakes and ask the student to correct them. The 
point is that because a tutor and a student do not want to waste each others' time, they will 
match the severity of the error with the severity of the feedback. 

In the ICAT model of feedback, there are four levels of severity of error and four corresponding 
levels of feedback. The tutor goes through the student's work, identifies the severity of the error 
and then provides the corresponding level of feedback. 



Educational Categories of Feedback 


ERROR 


FEEDBACK 


Error Type 


Description 


Feedback 
Type 


Description 


1. None 


No errors exist. 
The student's 
work is perfect. 


1. Praise 


Confirmation that the student 
completed the task correctly. 

Example: 

Great. You have journalized 
all accounts correctly. I am 
happy to see you recognized 
we are paying for most of 



55 



AND1P045.P 









our bills "on account". 


2. Syntactic 


There may be 
spelling 
mistakes or 
other syntactic 
errors. Asa 
designer, you 
should be 
confident that 
the student will 
have mastered 
the material at 
this point. 


2. Polish 


Tells the student the specific 
actions he did incorrectly, 
and possibly correct them for 
him. 

Example: 

There are one or two errors 
in your work. It looks like 
you misclassified the 
purchase of the fax as a cash 
purchase when it is really a 
purchase on account. 


3. Local 


A paragraph of 
a paper is 
missing or the 
student has 
made a number 
of mistakes all 
in one area. 
The student 
clearly does not 
understand this 
area. 


3. Focus 


Focus the student on this 
area of his work. Point out 
that he does not understand 
at least one major concept. 

Example: 

Looking over your work, I 
see that you do not 
understand the concept of 
on account . Why don t 
you review that concept and 
review your work for errors. 


4. Global 


The student has 
written on the 
wrong subject 
or there are 
mistaKes an 
over the 
student's work 


4. Redirect 


Restate the goal of the 
activity and tell the student 
to review main concepts and 
retry the activity. 

Example: 

There are lots of mistakes 
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wViirh indicates 




throughout your work. You 




hp Hoes not 




need to think about what 




understand most 




type of transaction each 




of the concepts 




source document represents 




in the activity. 




before journalizing it. 



Returning to the analogy of helping someone write a paper, if the student writes on the wrong 
subject, this as a global error requiring redirect feedback. If the student returns with the paper 
rewritten, but with many errors in one area of the paper, focus feedback is needed. With all of 
5 those errors fixed and only spelling mistakes-syntactic mistakes-polish feedback is needed. 
When all syntactic mistakes were corrected, the tutor would return praise and restate why the 
student had written the correct paper. 

Z Focusing on the educational components of completing a task is not enough. As any teacher 
0 1 0 knows, student will often try and cheat their way through a task. Students may do no work and 
m hope the teacher does not notice or the student may only do minor changes in hope of a hint or 
part of the answer. To accommodate these administrative functions, there are three additional 

,1! ;i 

yl administrative categories of feedback. 



Administrative Categories of Feedback 


Error 


Description 


Feedback 


Description 


No work 


The student has made 


Mastermind 


Tell the student that he has 


done since 


no changes since the 




done no work and that a 


last review 


last time he asked for 




substantial amount of work 




the tutor to review his 




needs to be completed before 




work. 




review. 








Example: 








You have done no work since I 








last reviewed your work. 








Please try and correct at least 








three journal entries before 



57 











asking me to review your work 










again. 




A 11 work is 


Tf a designer wants to 


ncomnlete- 


State that the student has not 




nnt 


cnvp an intprirn rpnort 

tlV^/ Cll 1 ill t VI ill 1 lV/L/V/xl. 


continue 


completed all of the work 




comnlete 


of how the student is 




required, but you will review 




Hut a 


doin*? before 




what the student has done so 




substantial 


pvervthim? is done 

\s V vl V VA1111 lO VlvJLlVj 




::ar. 




amount of 


they he would use 








work has 


incomplete-continue. 




Example: 




been done 






It looks like you have not 
finished journalizing, but I will 
review what you have done up 
to this point. The first three 
entries are correct. 




A 1 1 \\Tf\r\r i c 
r\lL WUIJv lo 


11 a UoCl lido llUl 


Tn c run v\\ ptp- 

JJLl \j\Jl 11 \J 1 w It/ 


Statp that nothing? has been 

Ululv 1 11CIL 11W tlllllg) lid-O 




tint 


pnmtilptpfl pnondi 

V^VJlllJJlWlVvU. WilvJ U-g,ll 


stor> 


attemnted and noint to the first 

LlLlVlHULwU <_t I lVl U Villi W VHv U \s 










aption to be taken 

ClV^UVJll KAJ *J\-> LCliV^li. 


M S 

IM 


dnu d 


f^»^Hl^Qr*lr tViic r^atp rrr\t*\/ 
iCeuudL/lv, llllo CdlCgUiy 








substantial 


is used. 




Example: 




amount of 






It looks like you have done no 


,^ 

).* 


work is not 
complete 






work journalizing. Why don't 
you start by trying to 
journalize the fax purchase. 



The administrative and the educational categories of feedback account for every piece of 
feedback a designer can write and a student can receive. To provide a better 
5 understanding of how the feedback works together, an example is provided below. 

Feedback Example 

The following example is a GBS training application in which new finance professionals are 

taught the fundamentals of finance management. A student has a toolbar to navigate and also to 
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access some of the application-level features of the application. The toolbar is the L-shaped 
object across the top and left of the interface. The top section of the toolbar allows the user to 
navigate to tasks within the current Activity. The left section of the toolbar allows the student to 
access other features of the application, including feedback. The student can have his 
5 deliverables analyzed and receive feedback by clicking on a team button. 

In this task, the student must journalize twenty-two invoices and other source documents to 
record the flow of budget dollars between internal accounts. (Note: "Journalizing", or 
"Journalization", is the process of recording journal entries in a general ledger from invoices or 
10 other source documents during an accounting period. The process entails creating debit and 

balancing credit entries for each document. At the completion of this process, the general ledger 
records are used to create a trial balance and subsequent financial reports.) The student has 
several controls on the screen that must be manipulated to complete the task. The upper left 
area of the screen shows the current transaction. Each transaction has a corresponding journal 
C3 15 entry. The bottom of the screen shows the current journal entry. The Top two lines of the 
m journal entry are for Debits (DR) and the bottom two lines are for Credits (CR). As the student 

WW 

fy uses the 'Back' and 'Next' buttons to page through the transactions, the journal entry is also 
IM paged to stay in sync. 

U 20 Figure 12 is a GBS display in accordance with a preferred embodiment. The upper right area of 
pi the screen shows the account list. There are four types of accounts: Assets, Liabilities & Equity, 
0 Revenues, and Expenses. The user clicks on one of the tabs to show the accounts of the 

corresponding type. The student journalizes a transaction by dragging an account from the 
account list onto the journal entry Debits or Credits. The student then enters the dollar amounts 
25 to debit or credit each account in the entry. In the interface, as in real life, the student can have 
multi-legged journal entries (i.e., debiting or crediting multiple accounts). 

A Toolbar 1200 and the first transaction of this Task 1210 appear prominently on the display. 
The student can move forward and back through the stack of transactions. For each transaction, 
30 the student must identify which accounts to debit and which to credit. When the student is done, 
he clicks the Team button. 
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Figure 13 is a feedback display in accordance with a preferred embodiment. The student may 
attempt to outsmart the system by submitting without doing anything. The ICAT system 
identifies that the student has not done a substantial amount of work and returns the 
5 administrative feedback depicted in Figure 13. The feedback points out that nothing has been 
done, but it also states that if the student does some work, the tutor will focus on the first few 
journal entries. 

Figure 14 illustrates a display in which a student has made some mistakes in accordance with a 
10 preferred embodiment. The student tries to journalize the transaction depicted in Figure 14 
which reflects the capital needed to start the business. The student attempts to journalize the 
transaction by debiting the paid-in capital account and crediting the cash account for $210,000. 
Similarly, the student attempts to journalize the purchase of Government Bonds by debiting 
accounts receivable and crediting cash for $150,000 as shown in Figure 15. Figure 15 illustrates 
1 5 a journal entry simulation in accordance with a preferred embodiment. 

Figure 16 illustrates a simulated Bell Phone Bill journal entry in accordance with a preferred 
embodiment. The journal entry is accomplished by debiting Utilities Expenses and Crediting 
Cash for $700 each. 

20 
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Figure 17 illustrates a feedback display in accordance with a preferred embodiment. After 
attempting to journalize the first three transactions, the student submits his work and receives the 
feedback depicted in Figure 17. The feedback starts by focusing the student on the area of work 
being evaluated. The ICAT states that it is only looking at the first three journal entries. The 
25 feedback states that the first two entries are completely wrong, but the third is close. If the 

student had made large mistakes on each of the first three transactions, then the ICAT may have 
given redirect feedback, thinking a global error occurred. The third bullet point also highlights 
how specific the feedback can become, identifying near misses. 

30 Figures 18 and 19 illustrate a feedback display in accordance with a preferred embodiment. 
As a student attempts to correct transactions one and two unsuccessfully, the tutor starts to 
provide hints, stating that the student should debit an asset account and credit an equity account. 
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The ICAT continues to focus on the errors in the first three source documents and is giving 
progressively more specific hints. 

Figure 20 illustrates a feedback display in accordance with a preferred embodiment. With the 
5 specific hints provided as illustrated in Figure 19, the student correctly journalizes the source 
document. The ICAT, however, continues to focus the student on these first three journal 
entries as illustrated in Figure 20. The student finally completes the first three entries correctly. 
The feedback illustrated in Figure 20 informs the student of his success and instructs him to try 
to complete the rest of the transaction before submitting his deliverable again. This example 
10 illustrates the use of an effective technique called "baby-stepping". The student is helped 
through a small portion of the work to get him introduced to the concepts and the interface. 
After completing this, he is forced to attempt all of the remaining work before getting 
substantive feedback. This technique can be used to mimic the kind of interactions one could 
expect to receive from a mentor in real life. The three transactions above show a tiny fraction of 



P 15 the depth of student analysis and richness of remediation that the ICAT is capable of delivering. 

C3 



As mentioned earlier in the Remediation Model section, the tutor plays two roles in any course. 
SUl First, the tutor reviews the student's work and helps him/her understand the task and the 
1L associate concepts. Second the tutor is gatekeeper between sections. The tutor will not allow 

M 20 students to proceed to the next section of the course until they have gotten the current section 

S3 

jil' correct. To monitor student progress, the course has been broken into two components: 

a 

N Activity 

An activity is a business event, such as planning a company's financials or closing the books. 
Business events set the context of the course. Students learn the content so that they can 
25 complete the goals associates with each business event. The power of a GBS is in how it 
embeds the content a student needs to learn within the context of the business events. 

Task 

A task is a business deliverable that must be completed as part of a business event. Example 
tasks include completing journal entries while closing the books. There may be many Tasks in 
30 an activity, just as there may be many deliverables required to react to a business event in the 
real world. Deliverables produced in this application include a break-even analysis, a 
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transaction journal, a cost report, and a ratio analysis. The role of the tutor is to help the 
students complete the business deliverables associated with any business event. Students can 
always go backward, but they are limited from going forward, until the ICAT says that the 
business deliverable meets the required specifications. It is useful to think of the ICAT as a boss 
who reviews your work. The boss will not let you go on to the next task, or business deliverable, 
until you have correctly completed the current task. To help explain the concepts of an activity 
and task, here is a description of an ICAT implementation in accordance with a prefeired 
embodiment. 

A training application utilizing ICAT for a large product company is presented as an example. 
The training application is a revision of the first semester of a two year financial training 
program. Students learn finance by managing a simulated bicycle company for three years and 
using finance to solve business problems. At four places in the course, the students come 
together to present their analyses of the business. These presentations are live presentations to 
real business executives. 

In preparation for the pitches, the students complete computer-based modules. There are two 
major sections to each module, the accounting concepts and the activities. Students learn the 
concepts and ideas in the accounting concepts and apply the concepts in the activities. All of the 
modules together represent the different phases associated with running a business: Start 
Operations, Analyze Operations and Improve Operations. Each computer-based activity 
represents a business event, such as closing the books of the company. These business events 
provide context for the content the students learn in the course. In this way, students not only 
learn what the concepts are but when, how and why they should use them. 



Business Events — Activities 


1 . Financial Planning 


4. Closing the Books 


2. Recording Transactions 


5. Analyze the Books 


3 . Recording Transactions 


6. Improve Operations 



Figure 21 illustrates a simulation display in accordance with a preferred embodiment. 
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To show how the business events impact the company on a day to day basis, students complete a 
set of deliverables associated with each business event. The business deliverables students 
create in the training application are varied in form and content. Some example business 
deliverables are listed below in accordance with a preferred embodiment. 

5 

1 . An analysis of proforma financial statements 

Students perform break-even analysis to determine which of twelve business strategies to 
pursue. 

10 2. Journal entries 

Student journalize 20 of the transactions which occur in the third year of operations. 

3. Summaries of interviews with employees about operating plan variances 
J* Students get behind the numbers and figure out what is driving the variances. 

O 15 

X Design Scenario 

W This Scenario illustrates how the tools are used to support conceptual and detailed design of a 

01 

m BusSim application. Figure 22 illustrates the steps of the first scenario in accordance with a 

preferred embodiment. The designer has gathered requirements and determined that to support 
U 20 the client's learning objectives, a task is required that teaches journalization skills. The designer 
fi begins the design first by learning about journalization herself, and then by using the Knowledge 
C3 Workbench to sketch a hierarchy of the concepts she want the student to learn. At the most 
general level, she creates a root concept of 6 Journalization' . She refines this by defining sub- 
concepts of 'Cash related transactions', 'Expense related Transactions', and 'Expense on account 
25 transactions'. These are each further refined to whatever level of depth is required to support the 
quality of the learning and the fidelity of the simulation. 

The designer then designs the journalization interface. Since a great way to learn is by doing, 
she decides that the student should be asked to Journalize a set of transactions. She comes up 
30 with a set of twenty-two documents that typify those a finance professional might see on the job. 
They include the gamut of Asset, Expense, Liability and Equity, and Revenue transactions. Also 
included are some documents that are not supposed to be entered in the journal. These 
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'Distracters' are included because sometimes errant documents occur in real life. The designer 
then uses the Domain Model features in the Knowledge Workbench to paint a Journal. An entity 
is created in the Domain Model to represent each transaction and each source document. 
Based on the twenty-two documents that the designer chose, she can anticipate errors that the 
5 student might make. For these errors, she creates topics of feedback and populates them with 
text. She also creates topics of feedback to tell the student when they have succeeded. Feedback 
Topics are created to handle a variety of situations that the student may cause. 
The next step is to create profiles that the will trigger the topics in the concept tree (this task is 
not computational in nature, so the Transformation Component does not need to be configured) . 
1 0 A profile resolves to true when its conditions are met by the student's work. Each profile that 
resolves to true triggers a topic. 

To do some preliminary testing on the design, the designer invokes the Student Simulator Test 
Workbench. The designer can manipulate the Domain Model as if she were the student working 
in the interface. She drags accounts around to different transactions, indicating how she would 
£3 15 like them journalized. She also enters the dollar amounts that she would like to debit or credit 
^ each account. She submits her actions to the component engines to see the feedback the student 
PJ would get if he had performed the activity in the same way. All of this occurs in the test bench 

Ijb without an application interface. 

f 

U 

20 The last step in this phase is low-fi user testing. A test student interacts with a PowerPoint slide 
S or bitmap of the proposed application interface for the Journalization Task. A facilitator mimics 
O his actions in the test bench and tells him what the feedback would be. This simplifies low-fi 

user testing and helps the designer to identify usability issues earlier in the design when they are 

much cheaper to resolve. 

25 

Build Scenario 

Figures 23 and 24 illustrate the steps associated with a build scenario in accordance with a 
preferred embodiment. The instructional designer completes the initial interaction and interface 
designs as seen in the previous Scenario. After low-fi user testing, the Build Phase begins. 
30 Graphic artists use the designs to create the bitmaps that will make up the interface. These 
include bitmaps for the buttons, tabs, and transactions, as well as all the other screen widgets. 
The developer builds the interface using the bitmaps and adds the functionality that notifies the 
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Domain Model of student actions. Standard event-driven programming techniques are used to 
create code that will react to events in the interface during application execution and pass the 
appropriate information to the Domain Model. The developer does not need to have any deep 
knowledge about the content because she does not have to build any logic to support analysis of 
5 the student actions or feedback. The developer also codes the logic to rebuild the interface based 
on changes to the domain model. 

A few passes through these steps will typically be required to get the application communicating 
correctly with the components. The debug utilities and Regression Test Workbench streamline 
10 the process. After the application interface and component communication are functioning as 
designed, the task is migrated to Usability testing. 



Test Scenario 

£: This scenario demonstrates the cycle that the team goes through to test the application. It 

53 15 specifically addresses usability testing, but it is easy to see how the tools also benefit functional 

|5 and cognition testing. Again, we will use the Journalization Task as an example. Figure 24 

I'M illustrates a test scenario in accordance with a preferred embodiment. The test students work 

101 

Hi through the journalization activity. One of the students has made it over halfway through the 
task and has just attempted to journalize the sixteenth transaction. The student submits to the 
hh 20 Financial Coach, but the feedback comes back blank. The student notifies the facilitator who 
f£ right-clicks on the Financial Coach's face in the feedback window. A dialog pops up that shows 
O this is the twenty-seventh submission and shows some other details about the submission. The 
facilitator (or even the student in recent efforts) enters a text description of the problem, and fills 
out some other fields to indicate the nature and severity of the problem. All the student's work 
25 and the feedback they got for the twenty-seven submissions is posted to the User Acceptance 
Test (UAT) archive database. 

The instructional designer can review all the student histories in the UAT database and retrieve 
the session where the student in question attempted the Journalization Task. The designer then 
30 recreates the problem by replaying the student's twenty-seven submissions through the 
component engines using the Regression Test Workbench. The designer can then browse 
through each submission that the student made and view the work that the student did on the 
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submission, the feedback the student got, and the facilitator comments, if any. Now the designer 
can use the debugging tools to determine the source of the problem. In a few minutes, she is able 
to determine that additional profiles and topics are needed to address the specific combinations 
of mistakes the student made. She uses the Knowledge Workbench to design the new profiles 
5 and topics. She also adds a placeholder and a script for a video war story that supports the 

learning under these circumstances. The designer saves the new design of the task and reruns the 
Regression Test Workbench on the student's session with the new task design. After she is 
satisfied that the new profiles, topics, and war stories are giving the desired coverage, she ships 
the new task design file to user testing and it's rolled out to all of the users. 

10 

This example illustrates how a high effort, uncertain process (that once took days) can be 
reduced to a few hours using the BusSim Toolset. Cycle time can be reduced dramatically, and 
complexity, risk and difficulty can be almost eliminated. It shows the sharp contrast with the 

!U traditional development approach where new designs and new code can have many unintended 

O 15 consequences that are difficult to test. 

'bp 
;r : : ~'~ 

Execution Scenario: Student Administration 

jJl Figure 25 illustrates how the tool suite supports student administration in accordance with a 
j\ preferred embodiment. When a student first enters a course she performs a pre-test of his 
b k 20 financial skills and fills out an information sheet about his job role, level, etc. This information 
m is reported to the Domain Model. The Profiling Component analyzes the pre-test, information 
O sheet, and any other data to determine the specific learning needs of this student. A curriculum 
is dynamically configured from the Task Library for this student. The application configures its 
main navigational interface (if the app has one) to indicate that this student needs to learn 
25 Journalization, among other things. 

As the student progresses through the course, his performance indicates that his proficiency is 
growing more rapidly in some areas than in others. Based on this finding, his curriculum is 
altered to give him additional Tasks that will help him master the content he is having trouble 
30 with. Also, Tasks may be removed where he has demonstrated proficiency. While the student is 
performing the work in the Tasks, every action he takes, the feedback he gets, and any other 
indicators of performance are tracked in the Student Tracking Database. Periodically, part or all 
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of the tracked data are transmitted to a central location. The data can be used to verify that the 
student completed all of the work, and it can be further analyzed to measure his degree of 
mastery of the content. 

5 Execution Scenario: Student Interaction 

Figure 26 illustrates a suite to support a student interaction in accordance with a preferred 
embodiment. In this task the student is trying to journalize invoices. He sees a chart of 
accounts, an invoice, and the journal entry for each invoice. He journalizes a transaction by 
dragging and dropping an account from the chart of accounts onto the 'Debits' or the "Credits' 
10 line of the journal entry and entering the dollar amount of the debit or credit. He does this for 
each transaction. 

As the student interacts with the interface, all actions are reported to and recorded in the Domain 
Model. The Domain Model has a meta-model describing a transaction, its data, and what 

C3 15 information a journal entry contains. The actions of the student populates the entities in the 

£3 

15 domain model with the appropriate information. When the student is ready, he submits the work 

y to a simulated team member for review. This submission triggers the Analysis-Interpretation 

SI 

111 cycle. The Transformation Component is invoked and performs additional calculations on the 

I , data in the Domain Model, perhaps determining that Debits and Credits are unbalanced for a 

¥ h 20 given journal entry. 

| 

The Profiling Component can then perform rule-based pattern matching on the Domain Model, 
examining both the student actions and results of any Transformation Component analysis. 
Some of the profiles fire as they identify the mistakes and correct answers the student has given. 

25 Any profiles that fire activate topics in the Remediation Component. After the Profiling 

Component completes, the Remediation Component is invoked. The remediation algorithm 
searches the active topics in the tree of concepts to determine the best set of topics to deliver. 
This set may contain text, video, audio, URLs, even actions that manipulate the Domain Model. 
It is then assembled into prose-like paragraphs of text and media and presented to the student. 

30 The text feedback helps the student localize his journalization errors and understand why they 
are wrong and what is needed to correct the mistakes. The student is presented with the 
opportunity to view a video war story about the tax and legal consequences that arise from 
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incorrect journalization. He is also presented with links to the reference materials that describe 
the fundamentals of journalization. 

The Analysis-Interpretation cycle ends when any coach items that result in updates to the 
5 Domain Model have been posted and the interface is redrawn to represent the new domain data. 
In this case, the designer chose to highlight with a red check the transactions that the student 
journalized incorrectly. 

IIL The Functional Definition of the ICAT 

1 0 This section describes the feedback processes in accordance with a preferred embodiment. For 
each process, there is a definition of the process and a high-level description of the knowledge 
model. This definition is intended to give the reader a baseline understanding of some of the key 
components/objects in the model, so that he can proceed with the remaining sections of this 
paper. Refer to the Detailed Components of the ICAT for a more detailed description of each of 
0 15 the components within each knowledge model. To gain a general understanding of the ICAT, 
read only the general descriptions. To understand the ICAT deeply, read this section and the 
detailed component section regarding knowledge models and algorithms. These processes and 
algorithms embody the feedback model in the ICAT. There are six main processes in the ICAT, 
described below and in more detail on the following pages. 
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Remediation Process Diagram 

Figure 27 illustrates the remediation process in accordance with a preferred embodiment. 
Remediation starts as students interact with the application's interface (process #1). As the 
student tries to complete the business deliverable, the application sends messages to the ICAT 

25 about each action taken (process #2). When the student is done and submits work for review, the 
ICAT compares how the student completed the activity with how the designer stated the activity 
should be completed (this is called domain knowledge). From this comparison, the ICAT get a 
count of how many items are right, wrong or irrelevant (process #3). With the count complete, 
the ICAT tries to fire all rules (process #4). Any rules which fire activate a coach topic (process 

30 #5). The feedback algorithm selects pieces of feedback to show and composes them into 

coherent paragraphs of text (process #6). Finally, as part of creating feedback text paragraphs, 
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the 1CAT replaces all variables in the feedback with specifics from the student's work. This 
gives the feedback even more specificity, so that it is truly customized to each student's actions. 

1. Student interacts with interface to create business deliverable 
5 Description 

The student completes the deliverables of the Task by interacting with the interface objects. 
These actions may be button clicks, dragging of text, selection of items from a list, etc. An 
example is the Journalization task shown below. Figure 28 illustrates a display of journalization 
transactions in accordance with a preferred embodiment. To interact with the display, the 
1 0 student must journalize the twenty- four transactions presented. To journalize a transaction, the 
student clicks the "next" and "previous" buttons to move between transactions. Once at a 
transaction, the student clicks and drags an account name from the chart of accounts- which is 
split into Assets, Liabilities, Revenues and Expenses— onto the debit or credit side of the journal 
entry. Once the journal entry has been made, the student must type in how much to debit or 
C3 15 credit. Each one of these buttons, draggable items, and text fields are interface objects which can 
m be manipulated. 



Knowledge Model 
!\ Interface Objects 

Ipt 20 In any GBS Task, the student must manipulate controls on the application interface to complete 
isJS the required deliverables. Figure 29 illustrates the objects for the journalization task in 



O accordance with a preferred embodiment. 



The following abstract objects are used to model all the various types of interface interactions. 
25 Sourceltem 

A Sourceltem is an object the student uses to complete a task. In the journalization example, the 
student makes a debit and credit for each transaction. The student has a finite set of accounts 
with which to respond for each transaction. Each account that appears in the interface has a 
corresponding Sourceltem object. In other words, the items the student can manipulate to 
30 complete the task (account names) are called Sourceltems. 
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Source 

A Source is an object that groups a set of Sourceltem objects together. Source objects have a 
One-To-Many relationship with Sourceltem objects. In the journalization example, there are 
four types of accounts: Assets, Liabilities and Equity, Revenues, and Expenses. Each Account is 
5 of one and only one of these types and thus appears only under the appropriate tab. For each of 
the Account type tabs, there is a corresponding Source Object. 

Target 

A Target is a fixed place where students place Sourceltems to complete a task. In the 
10 journalization example, the student places accounts on two possible targets: debits and credits. 
The top two lines of the journal entry control are Debit targets and the bottom two lines are 
Credit targets. These two targets are specific to the twelfth transaction. 

E TargetPage 

C3 15 A TargetPage is an object that groups a set of Target objects together. TargetPage objects have a 

% One-To-Many relationship with Target objects (just like the Source to Sourceltem relationship). 

!W In the journalization example, there is one journal entry for each of the twenty-two transactions. 

tfl For each journal entry there is a corresponding TargetPage object that contains the Debits Target 

; and Credits Target for that journal entry. 

if"'" 

20 

2. Reporting student actions to the ICA T 

p Description 

As the student manipulates the application interface, each action is reported to the ICAT. In 
order to tell the ICAT what actions were taken, the application calls to a database and asks for a 

25 specific interface control's ID. When the application has the ID of the target control and the 
Sourceltem control, the application notifies the ICAT about the Target to Sourceltem mapping. 
In other words, every time a student manipulates a source item and associates it with a target 
(e.g., dragging an account name to a debit line in the journal), the user action is recorded as a 
mapping of the source item to the target. This mapping is called a UserSourceltemTarget. 

30 Figure 30 illustrates the mapping of a source item to a target item in accordance with a preferred 
embodiment. 
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3. Student submits deliverables to one team member 

Description 

When the student is ready, he submits his work to one of the simulated team members by 
5 clicking on the team member's icon. When the ICAT receives the student's work, it calculates 
how much of the work is correct by concept. Concepts in our journalization activity will include 
Debits, Credits, Asset Accounts, etc. For each of these concepts, the ICAT will review all 
student actions and determine how many of the student actions were correct. In order for the 
ICAT to understand which targets on the interface are associated with each concept, the targets 
10 are bundled into target groups and prioritized in a hierarchy. Figure 31 illustrates target group 
bundles in accordance with a preferred embodiment. For each target group-or concept, such as 
debit-a number of aggregate values will be calculated. These aggregate values determine how 
many student actions were right, wrong or irrelevant. 

1 5 Knowledge Model 
TargetGroup 

A TargetGroup object represents a concept being learned. It is a group of Target objects related 
on a conceptual level. The TargetGroup objects in a Task are arranged in a hierarchy related to 
the hierarchy of concepts the student must learn. By analyzing the student's responses to the 
20 Targets in a TargetGroup, the ICAT can determine how well a student knows the concept. By 
Jjjj utilizing the conceptual hierarchy of TargetGroups the ICAT can determine the most appropriate 
remediation to deliver to help the student understand the concepts. 
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TargetGroup Hierarchy 

25 The TargetGroup objects in a Task are arranged in a hierarchical tree structure to model the 

varying specificity of concepts and sub-concepts being learned in the Task. The designer defines 
the parent-child relationships between the TargetGroups to mimic the relationships of the real 
world concepts. This hierarchy is used in the determination of the most appropriate feedback to 
deliver. Concepts that are higher (more parent-like) in the TargetGroup structure are remediated 

30 before concepts that are modeled lower (children, grandchildren, etc.) in the tree. Figure 32 
illustrates a TargetGroup Hierarchy in accordance with a preferred embodiment. 
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In the journalization example, the main concept being taught is journalization. The concept of 
journalization can be divided into more specific sub-concepts, for example journalizing cash-for- 
expense transactions and journalizing expense-on-account transactions. These may further be 
divided as necessary. The designer teaches this conceptual knowledge to the ICAT by creating 
a TargetGroup called "Journalizing Transactions" with two child TargetGroups "Journalizing 
Cash for Expense Transactions" and "Journalizing Expense On Account Transactions". The top- 
most TargetGroup in the Task, "Journalizing Transactions" contains all of the transactions in the 
Task. Child target groups will include just the first three transactions and transactions four to 
twenty. 

Therefore when the when the ICAT determines how much of the task is correct, it will calculate 
values for the first three journal entries and the next sixteen. Calculating these two separate 
numbers will allow the ICAT to provide specific feedback about the first three and separate 
feedback about the next sixteen transactions. Here is a section of the target group hierarchy for 
the journalize task. Figure 33 illustrates a small section the amount of feedback in accordance 
with a preferred embodiment. By analyzing the responses to the targets in the each of the 
targetgroups, we can determine how many of the transactions the student has attempted, whether 
mistakes were made, what the mistakes were, etc. We can then assemble feedback that is very 
specific to the way the student completed the deliverables. By analyzing the student's responses 
to a group of conceptually related requests, we can determine the degree of success with which 
the student is learning the concept. 

4. ICAT analyzes deliverables with Rules 

Description 

After the ICAT has calculated the aggregate values for the student's deliverables, it analyzes the 
deliverables by attempting to fire all of the Rules for that task. Rules that can fire, activate 
CoachTopics. Figure 34 illustrates an analysis of rules in accordance with a preferred 
embodiment. 
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5. Select appropriate remediation coach topics 
Description 

Once all possible coach topics are activated, a feedback selection analyzes the active pieces of 
remediation within the concept hierarchy and selects the most appropriate for delivery. The 
5 selected pieces of feedback are then assembled into a cohesive paragraph of feedback and 

delivered to the student. Figure 35 illustrates a feedback selection in accordance with a preferred 
embodiment. 

Feedback Selection Algorithm 

After the ICAT has activated CoachTopics via Rule firings, the Feedback Selection Algorithm is 
used to determine the most appropriate set of Coachltems (specific pieces of feedback text 
associated with a CoachTopic) to deliver. The Algorithm accomplishes this by analyzing the 
concept hierarchy (TargetGroup tree), the active CoachTopics, and the usage history of the 
Coachltems. Figure 36 is a flowchart of the feedback logic in accordance with a preferred 
embodiment. There are five main areas to the feedback logic which execute sequentially as 
listed below. First, the algorithm looks through the target groups and looks for the top-most 
target group with an active coach topic in it. Second, the algorithm then looks to see if that top- 
most coach item is praise feedback. If it is praise feedback, then the student has correctly 
completed the business deliverable and the ICAT will stop and return that coach item. Third, if 
the feedback is not Praise, then the ICAT will look to see if it is redirect, polish, mastermind or 
incomplete-stop. If it is any of these, then the algorithm will stop and return that feedback to the 
user. Fourth, if the feedback is focus, then the algorithm looks to the children target groups and 
groups any active feedback in these target groups with the focus group header. Fifth, once the 
feedback has been gathered, then the substitution language is run which replaces substitution 
variables with the proper names. 

Once the ICAT has chosen the pieces of feedback to return, the feedback pieces are assembled 
into a paragraph. With the paragraph assembled, the ICAT goes through and replaces all 
variables. There are specific variables for Sourceltems and Targets. Variables give feedback 
30 specificity. The feedback can point out which wrong Sourceltems were placed on which 

Targets. It also provides hints by providing one or two Sourceltems which are mapped to the 
Target. 
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IV. The ICAT Development Methodology for creating Feedback 
The Steps Involved in Creating Feedback 

The goal of feedback is to help a student complete a business deliverable. The tutor needs to 
5 identify which concepts the student understands and which he does not. The tutor needs to tell 
the student about his problems and help him understand the concepts. 

There are seven major steps involved in developing feedback for an application. 

10 First, creating a strategy — The designer defines what the student should know. 

Second, limit errors through interface — The designer determines if the interface will identify 
some low level mistakes. 

Third, creating a target group hierarchy — The designer represents that knowledge in the tutor. 
%' Fourth, sequencing the target group hierarchy — The designer tells the tutor which concepts 
0 15 should be diagnosed first. 

m Fifth, writing feedback — The designer writes feedback which tells the student how he did and 
what to do next. 

jSSKj 

fjl Sixth, writing Levels of Feedback — The designer writes different levels of feedback in case the 
■ student makes the same mistake more than once. 

iM 20 Seventh, writing rules — The designer defines patterns which fire the feedback. 

w Creating a Feedback Strategy 

A feedback strategy is a loose set of questions which guide the designer as he creates rules and 
feedback. The strategy describes what the student should learn, how he will try and create the 
25 business deliverable and how an expert completes the deliverable. The goal of the application 
should be for the student to transition from the novice model to the expert model. 

What should the student know after using the application? 

The first task a designer needs to complete is to define exactly what knowledge a student must 
30 learn by the end of the interaction. Should the student know specific pieces of knowledge, such 
as formulas? Or, should the student understand high level strategies and detailed business 
processes? This knowledge is the foundation of the feedback strategy. The tutor needs to 
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identify if the student has used the knowledge correctly, or if there were mistakes. An example 
is the journal task. For this activity, students need to know the purpose of the journalizing 
activity, the specific accounts to debit/credit, mid how much to debit/credit. A student's 
debit/credit is not correct or incorrect in isolation, but correct and incorrect in connection with 
5 the dollars debited/credited. 
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Because there are two different types of knowledge-accounts to debit/credit and amounts to 
debit/credit— the feedback needs to identify and provide appropriate feedback for both types of 
mistakes. 

10 

How will a novice try and complete the task? 

Designers should start by defining how they believe a novice will try and complete the task. 

Which areas are hard and which are easy for the student. This novice view is the mental model a 
|? student will bring to the task and the feedback should help the student move to an expert view. 
13 15 Designers should pay special attention to characteristic mistakes they believe the student will 
|C make. Designers will want to create specific feedback for these mistakes. An example is mixing 
1W up expense accounts in the journal activity. Because students may mix up some of these 
ill accounts, the designer may need to write special feedback to help clear up any confusion. 

H 20 How does an expert complete the task? 

in 

a! This is the expert model of completing the task. The feedback should help students transition to 

19 this understanding of the domain. When creating feedback, a designer should incorporate key 

features of the expert model into the praise feedback he writes. When a student completes 
portion of the task, positive reinforcement should be provided which confirms to the student that 
25 he is doing the task correctly and can use the same process to complete the other tasks. 

These four questions are not an outline for creating feedback, but they define what the feedback 
and the whole application needs to accomplish. The designer should make sure that the feedback 
evaluates all of the knowledge a student should learn. In addition, the feedback should be able to 
30 remediate any characteristic mistakes the designer feels the student will make. Finally, the 
designer should group feedback so that it returns feedback as if it were an expert. With these 
components identified, a designer is ready to start creating target group hierarchies. 
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Limit Errors Through Interface 

When the designer defines a feedback strategy, the designer defines the skills he wants the 
student to learn and the mistakes he thinks the student will make. Not all of the mistakes need to 

5 be corrected with ICAT generated feedback, some can be limited with or remediated through the 
interface. Limiting mistakes with the interface simply means that the system pops-up a message 
as the student works, identifying a mistake. An example interface corrected error is in the 
journalization activity when the interface points out that debits do not equal credits. Here, this is 
a low level mistake which is more appropriate to remediate through the interface than through 

10 the ICAT. The application simply check to see if the debit number equal the credit number and 
if they do not then the system message is returned. Figure 37 illustrates an example of 
separating out some mistakes for the interface to catch and others for the ICAT to catch has 
positive and negative impacts in accordance with a preferred embodiment. 

15 Positive 

The most obvious reason for eliminating mistakes through the interface is that can be easier for 
the designer and developer to catch them at this level than to leave them for the ICAT. 

Negative 

20 The reason to avoid interface-driven feedback is that it splinters the feedback approach which 
can make the job of creating a coherent feedback approach more difficult. 

Because there are positive and negative repercussions, designers need to select the when to 
remediate through the interface carefully. The criteria for making the decision is if the mistake is 

25 a low level data entry mistake or a high level intellectual mistake. If the mistake is a low level 
mistake, such as miss-typing data, it may be appropriate to remediate via the interface. If the 
designer decides to have the interface point out the mistakes, it should look as if the system 
generated the message. System generated messages are mechanical checks, requiring no 
complex reasoning. In contrast, complex reasoning, such as why a student chose a certain type 

30 of account to credit or debit should be remediated through the ICAT. 
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System messages 

It is very important that the student know what type of remediation he is going to get from each 
source of information. Interface based remediation should look and feel like system messages. 
They should use a different interface from the ICAT remediation and should have a different 
5 feel. In the journalization task described throughout this paper, there is a system message which 
states "Credits do not equal debits/' This message is delivered through a different interface and 
the blunt short sentence is unlike all other remediation. 

The motivation for this is that low level data entry mistakes do not show misunderstanding but 
10 instead sloppy work. Sloppy-work mistakes do not require a great deal of reasoning about why 
they occurred instead, they simply need to be identified. High-level reasoning mistakes, 
however, do require a great deal of reasoning about why they occurred, and the ICAT provides 
tools, such as target groups, to help with complex reasoning. Target group hierarchies allow 
designers to group mistakes and concepts together and ensure that they are remediated at the 

.0 1 5 most appropriate time (i.e., Hard concepts will be remediated before easy concepts). Timing and 

O 

other types of human-like remediation require the ICAT; other low-level mistakes which do not 
W require much reasoning include: 

J Incomplete 

j** 20 If the task requires a number of inputs, the interface can check that they have all been entered 
before allowing the student to proceed. By catching empty fields early in the process, the 
student may be saved the frustration of having to look through each entry to try and find the 
empty one. 

25 Empty 

A simple check for the system is to look and see if anything has been selected or entered. If 
nothing has been selected, it may be appropriate for the system to generate a message stating 
"You must complete X before proceeding". 

30 Numbers not matching 

Another quick check is matching numbers. As in the journalization activity, is often useful to 
put a quick interface check in place to make sure numbers which must match do. Small data 
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entry mistakes are often better remediated at the interface level than at the tutor or coach level 
(when they are not critical to the learning objectives of the course). 

There are two main issues which must be remembered when using the interface to remediate 
5 errors. First, make sure the interface is remediating low level data entry errors. Second, make 
sure the feedback looks and feels different from the ICAT feedback. The interface feedback 
should look and feel like it is generated from the system while the ICAT feedback must look as 
if it were generated from an intelligent coach who is watching over the student as he works. 

1 0 Creating the Target Group Hierarchy 

Target groups are sets of targets which are evaluated as one. Returning to the severity principle 
of the feedback theory, it is clear that the tutor needs to identify how much of the activity the 
student does not understand. Is it a global problem and the student does not understand anything 
Jl about the activity? Or, is it a local problem and the student simply is confused over one concept? 
ip 15 Using the feedback algorithm described earlier, the tutor will return the highest target group in 
!K which there is feedback. This algorithm requires that the designer start with large target groups 
PJ and make sub-groups which are children of the larger groups. The ICAT allows students to 
m group targets in more than one category. Therefore a debit target for transaction thirteen can be 
Jf in a target group for transaction thirteen entries as well as a target group about debits and a target 

I* 20 group which includes all source documents. Target should be grouped with four key ideas in 
mind. Target groups are grouped according to: 

U f 

O Concepts taught 

Interface constraints 
Avoidance of information overload 
25 Positive reinforcement 

The most important issue when creating target groups is to create them along the concepts 
students need to know to achieve the goal. Grouping targets into groups which are analogous to 
the concepts a student needs to know, allows the tutor to review the concepts and see which 
30 concepts confuse the student. As a first step, a designer should identify in an unstructured 
manner all of the concepts in the domain. This first pass will be a large list which includes 
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concepts at a variety of granularities, from small specific concepts to broad general concepts. 
These concepts are most likely directly related to the learning objectives of the course. 

With all of the concepts defined, designers need to identify all of the targets which are in each 
target group. Some targets will be in more than one target group. When a target is in more than 
one target group, it means that there is some type of relationship such as a child relationship or a 
part to whole relationship. The point is not to create a structured list of concepts but a 
comprehensive list. Structuring them into a hierarchy will be the second step of the process. 

In the journalization activity, the largest concept is the recording a transaction. Other important 
ideas are debits and credits. Debit and credit targets, however, are included in the overall 
transaction target group which means that it is either a part-whole relationship or a child 
relationship. Figure 38 is a block diagram of the hierarchical relationship of a transaction in 
accordance with a preferred embodiment. 

Concepts Taught: Part-whole Concepts 

With all of the target groups laid out, the designer needs to identify the relationships between 
concepts. One type of relationship is the part-whole relationship. Part-whole relationships-as 
the name denotes-identified which sub-components make up larger concepts. Identifying these 
relationships is important because the tutor will want to see if the student does not understand the 
whole concept or just one part. If there are no major errors in the concept as a whole, then the 
tutor will look to see if the student made any major errors in one part of the concept. 



Example: 

In the journalizing activity, there will be a target group called transaction. In transaction, there 
are two parts: debits and credits. When the tutor reviews the student's work, if there are no 
problems with the target group transactions, then the tutor will go to the next level and look for 
errors in the target group debits and credits. Because debits and credits are included in an overall 
transaction, there is a part-whole relationship to the concept transaction. 
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Concept Taught: Child Concepts 

In addition to part-whole relationships, designers need to identify child-parent relationships. In 
contrast to part-whole relationships, child-parent relationships define instances of abstract 
5 concepts. An example is "The dictionary is a book". "Dictionary" is a child concept to "book". 
The "dictionary" concept has all of the attributes of the "book" concept, and it is an instance of 
the concept which means that it contains extra attributes. Students may understand the concept 
in general but may be confused about a particular instance. 

10 Example: 

In the journalization activity, the concept transaction can be broken down into two sections: the 
debit and the credit. And each of those can be specialized into specialization categories, such as 
a credit to "Accounts payable". Students may not be confused about debits but the instance 

hi; 

"Accounts Payable". 

| 15 

% Interface Constraints 

IU Interface Constraint: Business Deliverable 

tjl When creating target group hierarchies, designers need to consider the type of deliverable the 
! student is creating. For each of the sections of the deliverable, the designer needs to create a 

hi* 20 target group. The target groups should contain an orderly structure, such as moving from top to 
JjS bottom. Reviewing the deliverable in the order it is created structures the critique so that 
C3 students know where to look next, after receiving feedback. In the current Intelligent Tutoring 

Fi f 

Agent, this structuring of feedback around the student-created deliverable can be accomplished 
in two ways. First, the designer can make every section of the deliverable a target. In addition, 
25 the designer can make some sections targets and some modifying attributes. Modifying 
attributes can be remediated on specifically, or in conjunction with the target. 

In the journalization activity, the sections of the product— the journal entry— mirrors the concepts 
involved-debits and credits. But there are a few extra items on the journal which are (in most 
30 cases) not involved in the main concepts being taught, and these are the dollar amounts to be 

journalized. The dollar amounts which are journalized are associated with the journal entry as an 
attribute. Attributes modify the source item (account name), which makes it possible to tell if 
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the source item is correct alone or with the attribute attached. As a designer, feedback should be 
created which takes all of this into account. Students should be told if they have the journal 
entry correct and the amount wrong, or if they have the whole thing wrong. 

5 Interface Constraint: Screen Space 

Many times one concept will span many sections of the interface. It is important to group the 
target groups so that they are interface specific. Therefore, even though one product may span 
multiple interfaces, the target groups should be centered around the interfaces so that the students 
receive feedback only about what they can see. 

10 

In the journalization activity, the sections of the deliverable-the collection of journal entries in 
the ledger — span many separate interfaces. Each source document must be seen individually. 
Therefore, some target groups are organized across all source documents — such as all debits — 
C and others are specific to the individual source documents — such as that source document's 
O 15 debits. The target group's hierarchy must include a section for across source documents — across 
m interfaces — and those within one source document — one interface. 

jf: jj 

s 

jjj] Information Overload 

If , As with any real-life tutor, you do not want to give too much information for the student to 

M 20 digest at once. If there are twenty-five problems, the tutor should not give feedback about all 
p errors simultaneously. Instead, the tutor should give feedback about just two or three things 
which the student can correct before asking for more feedback. 

In the journalization activity, there are a limited number of targets on the interface at one time- 
25 one debit and one credit. But if it were the whole General Ledger, it could have too many pieces 
of feedback for the student to digest at once and could overwhelm the student. In this case, the 
designer should scale the feedback so that just a handful come back at once. This is best done by 
having small target groups defined, but can also be done by identifying to the tutor how many 
different pieces of remediation are appropriate to deliver at one time. 

30 
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Positive Reinforcement 

In addition to creating target groups which are small in size, designers may want to create target 
groups which evaluate the first few steps a student makes. These early target groups will allow 
the student to see if he is on track and understand the goal of the interaction. This is, in general, 
5 a good remediation strategy, but may not be relevant in all learning situations. 

In the journalization activity, there are twenty source documents to journalize. Students should 
NOT be encouraged to ask for feedback at every step, but when they have completed all of their 
work. This will ensure that students try and learn all of the information first and not rely 
10 completely on the hints of the tutor. But, target groups defined for just the first three entries 
allow for feedback and hints to be provided at the onset of the task, diminishing once these 
entries are correct. 

n.i.. 

j£ Sequencing the Target Group Hierarchy 

0 15 For feedback to be as effective as possible, it needs to provide the right information at the right 
S time. If feedback is given too early, it is confusing; if feedback is given too late it is frustrating. 

CM In the ICAT, feedback is returned according to Target Groups. The tutor will look at the highest 

|1 

target group, if there is no feedback in that target group, the tutor will look at the children target 
J , groups in order of priority. 

pk 20 

Jj=[ Figure 39 is a block diagram illustrating the feedback hierarchy in accordance with a preferred 

P embodiment. In Figure 39, the tutor will first look for any relevant feedback to be delivered in 

target group #1 A. If there is nothing there, then the tutor will look in the highest prioritized child 
target group — in the B tier. If there is nothing in that target group, then the tutor will look in the 
25 highest child target group of target group #1B which is target group #1C. Because the target 
group priority determines where the tutor looks for feedback within tier, a great deal of thought 
needs to be given to what comprises a target group and how they are structured. There are four 
guiding principles which will help structure target groups to provide the right information at the 
right time and help the student make the most of the information provided. 

30 
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Positive Reinforcement First 

Designers should identify the first few components a student will try and complete first and 
sequences them first. This target group will evaluate just the first few moves a student makes 
and will tell him how he is doing and how to apply the knowledge gained from the first few steps 
5 to the rest of the work he has to do. 

In the journalization activity, students need to have reinforcement that they are on the right track 
before trying all of the journal entries. Therefore, the first three are grouped together and 
students can feedback on how they completed this sub-group before having to complete the rest. 
10 Completing this subsection gives students the positive reinforcement they need to complete the 
rest. 

Easy Before Hard 

If all of the target groups are of equivalent size, designers need to sequence easier concepts 
Q 15 before more complicated concepts. By placing easier concepts first, a student will gain 
S confidence in their understanding of the domain and in their ability to complete the deliverable. 
PJ In addition, most complicated concepts are built on easier ones so that presenting easier concepts 
ijsj first will allow the student to gain the experience they need to complete the most complicated 

concepts. In the journalization activity, two legged journal entries are inherently easier than 
hh 20 three legged and four legged journal entries. Therefore when a designer must sequence target 

groups of equal size, the designer should sequence the two legged journal entries before the three 
and four legged entries. 

First Things First 

25 Besides sequencing easier concepts before hard concepts, another strategy is to sequence target 
groups in order that they need to be completed. If completing one section of the deliverable is a 
prerequisite for completing another section of the deliverable, it makes sense to sequence those 
targets first. In the journalization activity, a source document needs to be journalized in terms of 
the account name and in terms of the dollar amount. However, the account name must be 
30 identified before the amount is entered. It makes no difference whether the dollar figure of the 
account is right or wrong, until the student has the correct account name. 
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Writing Feedback 

Creating and structuring target group hierarchies determines what is evaluated and the order the 
feedback is returned. Once the hierarchy has been created and structured, designers need to 
write feedback which will help the student complete his goal Going back to the goals of the 
5 tutor as educator, feedback needs to accomplish the following goals: 
Identify concepts students do not understand 
Identify student mistakes 
Prompt students to reflect on their mistakes 
Reinforce correct concepts and ideas 

10 

These goals can be thought of in two sections. The first two are evaluative and the second two 
are instructive . Evaluation and instruction are two of the three main components of a piece of 
feedback text. The third component is Scope. These three components are described in more 

J* detailed below, beginning with Scope, as it is generally the first portion of a piece of feedback 

15 15 text. 

fV What the Feedback is Evaluating ( Scope ) 

m The most important information feedback provides a student is what the tutor is reviewing. In 
7 most instances, the student will have completed lots of different actions before asking the tutor 

bh 20 to review his work. Because the student has completed a lot of different actions, the tutor first 
fi needs to describe what portion of the activity or deliverable is being reviewed. There are 
(3 generally three ways to scope what the tutor is reviewing. 

i: z 

; .p" 

All work 

25 The tutor is looking at everything the student did. Some instances when feedback should look at 
everything the student has done are praise level feedback and redirect level feedback. I looked 
at all of the journal entries and there are problems in many of them. Why don't you.... 

A localized area of work 
30 The tutor is looking at a subset of work the student completed. The greatest use of localized 
scoping if focus feedback. The feedback is focusing the student on one area of difficulty and 
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asking him to correct it. I am looking at the first five journal entries you made, and here are 
the first three problems I found. The first... 

A specific problem or error 
5 The tutor is focusing on one error and/or problem and helping the student understand that error. 
Specific problem scoping is good for classic mistakes a student may make and the designer may 
want to remediate. In the first journal entry, you incorrectly debited Accounts Payable. 
Review that transaction... 

1 0 How the Student Did ( Evaluation) 

The second section of the feedback text should describe how the student did. This is where the 
severity principle is applied and the feedback is either redirect, focus, polish or praise. 

it Redirect 

fi 

ip 15 Redirect feedback is appropriate for very severe errors: severe mistake sand misconceptions. 

IP?;- 

^ This degree of severity can be assessed aggregately by recognizing there are problems 
PJ throughout the student's work or it can be done specifically by recognizing some basic items are 
incorrect. 

P 

20 Example: 

|H . I am looking at the first five journal entries you made, and there are problems in most of them. 
19 Why don't you... I am looking at the first five journal entries you made, and you have made 
some basic mistakes with debits and credits. Why don't you... 

25 Focus 

Focus feedback is appropriate for localized mistakes or misconceptions. Focus level mistakes 
can be identified aggregately by identifying an area in which there are a number of mistakes or 
specifically by identifying that some of the building block ideas are wrong. 

30 Example: 

I am looking at the first five journal entries you made, and there are problems in many of the 
debits. Why don't you... 
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I am looking at the first five journal entries you made, I see problems when transactions are 
"on account". Why don't you... 

5 Polish 

Polish level feedback is for syntactic problems. Student understand the main ideas and have no 
local problems. There may be just one or two mistakes the student has made. Polish feedback 
should specify where the mistake is. 

10 Example: 

I am looking at the first five journal entries you made, and the third journal entry has the debit 
incorrect Why don't you... 

Praise 

u 

!p 15 Praise level feedback is reserved for instances of "correctness"; the deliverable is correct and 
ready to be used in the business. 

m 
m 
ui 

bh 20 

m 

"55 * 

Q Example: 

|?» 

I am looking at the first five journal entries you made, and they are all correct, remember... 
25 Mastermind 

Mastermind feedback is reserved for instances where the student is not trying to learn a topic but 
trying to cheat his way through by repeatedly asking for feedback. The feedback needs to be 
written so that the student recognizes that the tutor wants more work completed before providing 
feedback. 

30 

Example: 
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You have not changed much of your work since the last time you asked me to review it. 

Review... 

Incomplete 

Incomplete feedback is reserved for instances where the student has not completed all of the 
5 required work. It should be remembered that sometimes it is desired to give substantive 
feedback before everything is complete so the student learns the process and concepts before 
trying to complete the whole deliverable. 

Example: 

1 0 You have not done all of your work. I would like you to try completing all journal entries 
before asking for my review. 

What the Student Should Do Next ( Instruction ) 

S : 

The final piece of information the student needs is what to do next. The student knows what the 

%^ 

C3 1 5 tutor reviewed and knows how he performed. The only thing the student does not know is what 

£3 

m to do next. The type of instruction does not have to correspond with the severity of the error. 

The instructions can be mixed and matched with the type of error. Some of the actions a student 
fji could be asked to perform are as follows. 

p h 20 Review the general concept 

lS If the tutor recognizes that there are many errors throughout the deliverable, the tutor may 

P suggest that the student go through a review of the supporting materials provided to gain an 

understanding of the ideas and skills needed to complete the task. 

25 Example: 

There are problems in many journal entries, why don't you review how to journalize 
transactions and then review your journal entries. 

Review a section of the student's work 
30 If the student has many errors in one section, then the tutor may suggest that the student go and 
review that section of their work. 
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Example: 

There are problems in the first five journal entries, why don't you review them. 



Review work with a hint 

5 If there is a certain idea or concept which the tutor believes the student does not understand, then 
the tutor may give a hint in the form of a question or statement for the student to think about 
before trying to fix the problems. 



Example: 

1 0 There are problems in the first five journal entries. It looks like you have made some errors with 
the expense debits. Remember that expenses are not capitalized. Why don't you review the 
first five journal entries looking for journal entries which contained incorrect debits to 
expense accounts. 

Jp 15 Review work looking for type of error 

% If there is a specific type of error that the student has made throughout his work, then the tutor 
PJ may tell the student the specific type of error and ask him to go through his work correcting this 

jyi error. 

hk 20 Example: 

% There are problems in the first five journal entries. You have switched all of your journal 
Q entries on account debits. Why don't you go and fix them. 

Review work looking for specific error 
25 If there is a specific error that the student has committed, the tutor may tell the student the 
specific error committed and where the error is. 



Example: 

There is a problem with your third journal entry. The debit should not be "Accounts 
30 Payable." 
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Review work because it is correct and the student will want to use this analysis technique in the 
future. 

Example: 

5 Your first three journal entries are correct. Remember that the major distinction between 
paying for something "On Account" or in cash. This is a distinction you will need to make 
in the future. 

Do more work 

10 If it can be determined that the student is simply asking for feedback to "Cheat" his way through 
the course, feedback should be provided to tell the student that he needs to try and correct many 
more entries before receiving substantive feedback. 



f Z Example: 

3 15 You have not changed much of your work since the last time you asked me to review it. Please 



•i .:S5 
f 



review all of your journal entries and correct many of them. 



Complete your work 

U 20 When it can be determined that all of the work which should be complete is not, the feedback 
Jl needs to tell the student to complete the work required. 



Example: 

You have not completed all of your work. I would like you to try completing all journal 
25 entries before asking for my review. 

Writing Levels of Feedback 

Even with effective feedback, students will often make the same types of mistakes again or in 
30 different situations. The question is what to tell the student the second time he makes the same 
or similar mistakes. We assume that telling the student the same thing over and over is not the 
right answer. Therefore instead of telling the student the same thing, the feedback cycles to a 
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lower, or secondary, level At this time, we believe that three levels of feedback is appropriate 
for most instances. If the target group is particularly complex, however, additional levels of 
feedback may be required. 

First Level of Feedback 

The first level of feedback should focus more on telling the student what is wrong and letting 
the student try and figure it out on his own. Therefore using the paradigm described above, the 
student should be told what the tutor is reviewing, how he did and asked to retry it or referred to 
some reference which could be used to find the answer. 



Example: 

There are problems in many journal entries. Why don't you review how to journalize 
transactions and then review your work. 



1 1 Second Level of Feedback 

PJ The second level of feedback should give hints and provide pieces of the puzzle. I can be 
|fj assumed that students cannot figure out the problem on their own and need some help. It is 

appropriate at this point to ask the student to review their work with a specific hint in mind or 
hh 20 with a question to think about. Also, if there are specific points in the reference system to 
Jj review, this is the time to provide them. 



Example: 

25 There are problems in the first five journal entries. It looks like you have made some errors with 
expense debits. Remember that expenses are not capitalized. Why don't you review the first 
five journal entries looking for journal entries which contain incorrect debits to expense 
accounts. 

30 Third Level of Feedback 

The third level of feedback is appropriate for examples. Use the parameter substitution language 
to insert an example of an error they made into the feedback. Walk the student through the 
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thought process he should use to solve the problem and provide and example of how they did the 
work right and how they did the work wrong. 

Example: 

5 There are problems in many of your journal entries. It looks like you have made some errors 
distinguishing between "on account" and "cash" credits. In particular, you characterized journal 
entry #12 as a cash purchase when in fact it is an "on account" purchase. Remember bills which 
are not paid immediately are paid on account. 

10 Writing Rules 

With the hierarchies created and sequenced and the feedback written, the designer is ready to 
write rules. Rules fire the particular pieces of feedback the student reads. To write effective 
rules, designers must realize the piece of feedback and the rule are one and the same. The only 

Z difference is the language used. The feedback is written in English and the rules are written as 

3 15 patterns. 



y Example rule: 

If the student has attempted all of the first three journal entries 
And they all contain at least one mistake 
h 20 Then provide feedback "In the first three journal entries you have made at least one mistake in 
each. Why don't you review them and see if you can find the mistakes." 

In the above example, the rules has two conditions (attempt all three journal entries and have at 
least one mistake in each). The feedback is an explicit statement of that rule. The feedback 
25 states "In the first three journal entries you have made at least one mistake in each. Why don't 
you review them and see if you can find any mistakes." 

The rule and the feedback are exactly the same. Keeping the rules and the feedback tightly 
linked ensures that the student receives the highest quality feedback. The feedback exactly 
30 explains the problem the rules found. If the feedback is more vague than the rule, then the 

students will not understand the exact nature of the problem. The feedback will simply hint at it. 



[SAW. 
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If the feedback is more specific than the rule, students will become confused. The student may 
not have made the specific error the feedback is referring to under the umbrella rule. 

Types of Rules 

5 Because the rules need to map to the feedback, there will be six types of rules associated with the 
six types of feedback: Praise, Polish, Focus, and Redirect, along with Mastermind and 
Incomplete. 

Praise 

10 Praise rules need to look for one hundred percent correct and NO errors. If the rule does not 
explicitly look for no errors, the rule will also fire when the student has all of the right answers 
but also some of the wrong ones. 

8 15 If 100% of the targets in the first three journal entries are correct 

n 

p And they all contain no mistakes 

CV Then provide praise feedback 

m 

l . Praise rules can be applied in many places other than the highest task level. Praise rules can fire 

bh 20 for instances where a student got an item right. In general, these rules should be written for any 

Z% instance which poses a difficult problem and a student may need reinforcement as to how to 

O complete the process and complete the deliverable. 

25 Polish 

Polish rules need to fire when almost everything in the target group is correct and the student is 
making small and insignificant mistakes. 

30 If 80%-99% of the targets in the first three journal entries are correct 
And the first three journal entries have been tried 
Then provide polish feedback 
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This polish rule shows two things. First, the rule is scoped so that it will not fire when any of the 
first three journal entries have not been attempted. In addition, the rule will not fire if all of the 
journal entries are 100% correct. With these boundaries in place the rule will only fire when the 
5 student has attempted all of the first three journal entries and they are 80%-99% correct. Note: 
The determination of the exact percentages which must be correct to receive "polish" 
versus "focus" or "redirect" feedback will be determined by the designer, and are most 
likely specific to the particular task being completed. 

10 Focus 

Focus rules are the most common type of rule. Focus rules should fire when the student knows 
enough to complete the task but not enough to get the task correct. 



If 40%-79% of the targets in the first three journal entries are correct 

£3 1 5 And the first three journal entries have been tried 

fSh Then provide focus feedback 

m 

m This focus rule also shows scoping. The rules are scoped to fire between 40% and 79%. Below 

!f 40% is redirect and above 79% is polish. The rule also fires only when all of the required work 

!M : 20 has been attempted. 



Redirect 

Redirect rules should fire when it is clear that the student does not have a good understanding of 
how to complete the task. This is evidenced by a significant number of errors found in the 
25 student's work. 

If less than 40% of the first three journal entries are correct 
And the first three journal entries have been tried. 
Then provide redirect feedback 

30 
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This redirect rule is to catch those who are truly lost. If the student has tried to complete all of 
the work, and they are less than 40% correct, then they need a great deal of help to continue the 
task. 

Mastermind 

Mastermind rules need to track down situations when the student is simply trying to cheat his 
way through the application. 

If less than 40% of the first three journal entries are correct 
And the student has made only one change twice in a row. 
Then provide mastermind feedback 

This mastermind rule catches those who are making one change, asking for feedback over and 
over. One thing to keep in mind is that as a student gets towards praise they need to make small 
changes and then ask for feedback. To allow this, the above rule is scoped so that if the student 
has more than 40% of the work right the rule will not fire. 

Incomplete 

In many activities the student should try and complete most if not all of the work before asking 
for feedback. One of the goals of many training applications is to mimic the real world, and it is 
rare for an employee to ask for a review after every little step they complete. Most employers 
want to see a significant amount of work done before asking for a review. 

If all of journal entries have NOT been tried, 
Then provide incomplete feedback 

Forcing a student to attempt all of his work first will require him to gain confidence in his ability 
to complete the work. Therefore, incomplete rules should be used after baby-step feedback so 
that students feel that they have the tools and ability to complete the whole task before asking for 
feedback. 
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Principles of Rule Design 

There are a couple of general rules which make rule creation and maintenance easier. 
Use percentages whenever possible 

It may seem easier at the time to write rules which look for specific numbers of right and wrong 
items. But when a rule is written which looks for a specific number, it means that if the data 
ever changes, you will need to get back into that rule and tweak it so that it still fires at the right 
time. It is far better to write percentage rules which fire whenever a certain percentage of work 
is either right or wrong. Then if the data ever changes and more right answers are added or some 
removed, then the rules may not need to be rewritten. 

Scope the rules as tightly as possible 

As stated previously, it is very important to make the rules mirror the written feedback. If the 
feedback is vaguer than the rule, then the students will not understand the exact nature of the 
problem. The feedback will simply hint at it. If the feedback is more specific than the rule, 
students will become confused. The student may not have made the specific error the feedback 
is referring to under the umbrella rule. 

Data Dictionary In Accordance With 

A Preferred Embodiment 



Domain Knowledge Model Data Dictionary 
Column Type Len Description 



Source 




SourcelD 


Counter 




Unique key for this table 


Source 


String 


50 


Name of this object 


SourceDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation reports 


SourceCaption 


String 


50 


String that can be dynamically 
embedded into feedback text 
using Parameter Substitution 
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Language (PSL) 




Sourceltem 






SourceltemID 


Counter 




Unique key for this table 




Sourceltem 


String 


50 


Name of this Object 




SourceltemDesc 


String 


255 


Documentation String that 
appears with this object in 1 




SourceltemText 


String 


50 


String that Can be dynamically 
embedded into feedback text 
using Parameter Substitution 
Language (PSL) 




TargetPage 




Li. 


TargetPageED 


Counter 




Unique key for this table 




T 3 r <JP tP fl CTP 
X OX ci t/ IX clg^ 


String 


50 


Name of this object 


%fF 


TargetP ageDesc 


String 


255 


Documentation String that 


if! 1 








appears with this object in 


iiT'S 

yi 








auto-documentation reports 




1 argetr agecapt 


String 


50 


String that Can be dynamically 


ion 






embedded into feedback text 
using Parameter Substitution 










Language (PSL) 


y= 






Target 






TargetID 


Counter 




Unique key for this table 




Target 


String 


50 


Name of this object 




TargetDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation reports 




TargetCaption 


String 


50 


String that Can be dynamically 
embedded into feedback text 
using Parameter Substitution 
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Language (PSL) 


SourceltemTar 
get 




SourceltemED 


Long 




SourceltemED of the 
association 


TargetID 


Long 




TargetID of the association 


Relevance 


Float 




Value between -1 and 1 that 
indicates the relative relevance 
of this association between a 
Sourceltem and a Target. A 
negative value indicates that 
this association is incorrect. A 
positive value indicates that it 
is correct A value of zero 
indicates that this association is 
irrelevant. 




Attribute 




SourceltemED 


Long 




SourceltemED of the 
association 


TargetID 


Long 




TargetID of the association 


AttributelD 


Counter 




Unique key for this table 


Attribute 


String 


50 


Name of this object 


Correctlnd 


Bool 




Boolean value that indicates 
whether this Attribute is 
correct or incorrect for this 
association of Sourceltem and , 
Target 


AttributeMin 


Double 




The lower bound for the range 
of this attribute. 


AttributeMax 


Double 




The upper bound for the range 
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of this attribute. 




ControlSourcel 
tcm 




ModuleName 


String 


50 


Name of module the control is 
on 


ControlName 


String 


50 


Name of Control the 
Sourceltem is mapped to 


ItemNo 


Integer 




A single control may be 
mapped to multiple 
Sourceltems depending on how 
it is viewed. If one control is 
used on four different tabs to 
show four different values, the 
ItemNo will change as the tabs 
change, but the ControlName 
will stay the same. 


SourceltemID 


Long 




ID of Sourceltem that this 
control is mapped to 


Start 


Integer 




For controls that contain text, 
this is the start position of the 
text that the Sourceltem is 
associated with. 


End 


Integer 




For controls that contain text, 

tTiic ic tVif* f^nrl r\r\citirvn r\T tnf* 
IXIXo lo L11C CJLIUL LJvJ&llItJII Ul U.1C- 

text that the Sourceltem is 
associated with. 


TaskID 


Long 




This is the TaskID the module 
is in 


Description 


Text 


255 


Comment Information that can 
appear in the generated 
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documentation reports. 




ControlTarget 




ModuleName 


String 


50 


Name of module the control is 


ControlName 


String 


50 


Name of Control the 
Sourceltem is mapped to 


ItemNo 


Integer 




A single control may be 
mapped to multiple Targets 
depending on how it is viewed. 
If one control is used on four 
different tabs to show four 
different values, the ItemNo 
will change as the tabs change, 
but the ControlName will stay 
the same. 


TargetID 


Long 




ID of Target that this control is 
mapped to 


Start 


Integer 




For controls that contain text, 
this is the start position of the 
text that the Target is 
associated with. 


End 


T A. 

Integer 




For controls that contain text, | 
this is the end position of the 
text that the Target is 

dboUOlalcU. Willi. 


1 a.oJVJUU' 


Long 




This is the TaskED the module 
is in 


Description 


Text 


255 


Comment Information that can 
appear in the generated 
documentation reports. 
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Student Data Model Data Dictionary 

Column Type Len Description 



Student 




SourceED 


Counter 




Unique key for this table 


Source 


String 


50 


Name of this object 


SourceDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation reports 


SourceCaption 


String 


50 


String that Can be 
dynamically embedded into 
feedback text using Parameter 
Substitution Language (PSL) 




StudentSubmissi 
on 




SourceltemID 


Counter 




Unique key for this table 


Sourceltem 


String 


50 


Name of this Object 


SourceltemDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation reports 


SourceltemText 


String 


50 


String that Can be 
dynamically embedded into 
feedback text using Parameter 
Substitution Language (PSL) 




UserSourceltemTa 
rget 




SourceltemID 


Counter 




Unique key for this table 


Sourceltem 


String 


50 


Name of this Object 


SourceltemDesc 


String 


255 


Documentation String that 
appears with this object in 
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auto-documentation reports 


SourceltemText 


String 


50 


String that Can be 
dynamically embedded into 
feedback text using Parameter 
Substitution Language (PSL) 





101 



ANDIP045.P 



J J 



Rule Model Data Dictionary 





Column 


Type Len 


Description 




Rule 






TaskID 


Long 




ID of Task for which this 
rule is in scope 




CoachID 


Long 




ID of Coach for which this 
rule is in scope 




RulelD 


Counter 




Unique key for this table 




Rule 


String 


50 


Name of this object i 




RuleDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation 


h 








reports 


.r?Ta 
.^sr 

iy ; 

- : b • 


RuleCondCountMin 


Integer 




Minimum number of 
conditions that must be 
true for this Rule to fire 


: N * 


RuleCondCountMax 


Integer 




Maximum number of 


f* 








conditions that must be 










true for this Rule to fire 


yi 


CoachTopicID 


Long 




ID of CoachTopic that is 










activated when this rule 
fires 








RuleAggregateAnds 






RulelD 


Long 




ID of Rule of which this 
object is a condition 




RuleCondID 


Counter 




Unique key for this table 




TargetGroupID 


Long 




ID of TargetGroup whose 
aggregate values are 
compared to the aggregate 
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boundaries of this 
condition 


AggRelevanceMin 
AggRelevanceMax 


Float 




The TargetGroup' s 
Calculated Aggregate 
Relevance must fall 
between this Min and Max 
for this condition to be 
true 


AggUserCntPosMin 
AggUserCntPosMax ! 


Integer 




The positive-relevance 
associations the user has 
made using Targets in this 
TargetGroup are counted 
to produce an Aggregate 
value called c UserCntPos\ 
This TargetGroup ' s 
UserCntPos must fall 
between this condition's 
AggUserCntPosMin and 
AggUserCntPosMax for 
this condition to be true. 


AggUserCntNegMin 
AggUserCntNegMax 


Integer 




The negative-relevance 
associations the user has 
made using Targets in this 
TargetGroup are counted 
to produce an Aggregate 
value called 
'UserCntNeg 5 . This 
TargetGroup's 
UserCntNeg must fall 
between this condition's 
AggUserCntNegMin and 
AggUserCntNegMax for 
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this condition to be true. 




AggUserCntZeroMin 


Integer 




The zero-relevance 




AggUserCntZeroMax 






associations the user has 
made using Targets in this 
TargetGroup are counted 
to produce an Aggregate 
value called 
'UserCntZero'. This 
TargetGroup 's 
UserCntZero must fall 
between this condition's 
AggUserCntZeroMin and 
AggUserCntZeroMax for 


a 








this condition to be true. 


tt 


AggUserSumPosMin 


Float 




The relevance values of 


hi 
f& 


AggUserSumPosMax 






the positive-relevance 
associations the user has i 


i'.m 
■y g 








made using Targets in this 










TargetGroup are summed 


fl 








to produce an Aggregate 










value called 










'UserSumPos'. This 
TargetGroup 's 
UserSumPos must fall 
between this condition's 
AggUserSumPosMin and 
AggUserSumPosMax for 
this condition to be true. 




AggUserSumNegMin 


Float 




The relevance values of 




AggUserSumNegMa 






the negative-relevance 'i 




X 






associations the user has 
made using Targets in this 



J 
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TargetGroup are summed 
to produce an Aggregate 
value called 
'UserSumNeg'. This 
TargetGroup's 
UserSumNeg must fall 
between this condition's 
AggUserSumNegMin and 
AggUserSumNegMax for 
this condition to be true. 


AggUserCntPos2Min 
AggUserCntPos2Max 


Integer 




The positive-relevance 
associations the user has 
made using Targets in this 
TargetGroup where the 
user's Attribute are 
counted to produce an 
Aggregate value called 
c UserCntPos2\ This 
TargetGroup's 
UserCntPos2 must fall 
between this condition's 
AggUserCntPos2Min and 
AggUserCntPos2Max for 
this condition to be true. 


RuleSpecificMapping 
Ands 




RuleDD 


Long 




ID of Rule of which this 
object is a condition 


SourceltemED 


Long 




SourceltemE) of the 
association 


TargetE) 


Long 




Target© of the 
association 
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SourceltemID 


Long 




Unique key for this table 


AttributeMatchType 


Byte 






Attribute© 


Long 




Documentation String that 
appears with this object in 
auto-documentation 
reports 


AttributeMatchTyp 
e 




AttributeMatchType 


Byte 




Unique key for this table 


AttributeMatchType 
Desc 


String 


255 


Brief text description of 
each AttributeMatchType 
Type 
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Feedback Model Data Dictionary 

Column Type Len Description 



CoachTopic 




TaskE) 


Long 




ID of Task for which this 
object is in scope 


TargetGroupED 


Long 




ED of TargetGroup which this 
topic of remediation relates to 


CoachTopicID 


Counter 




Unique key for this table 


CoachTopic 


String 


50 


Name of this object 


CoachTopicDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation reports 


CoachTopicPriori 

ty 


String 


3 


Priority of this CoachTopic 
with respect to other 
CoachTopics in the same 
TargetGroup 


RemediationType 


String 


50 


Type of remediation that this 
CoachTopic is. This 
determines how the 
CoachTopic is handled at 
runtime. 


CoachltemStandA 

loneReentrySeql 

D 


String 


50 


When all the Stand Alone 
Coachltems in this 
CoachTopic have been used, 
they are restarted on the 
CoachltemStandAloneReentry 
SeqID. Ifthe 

CoachltemStandAloneReentry 
SeqID = 0 the StandAlone 
half of the CoachTopic is 
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expired and no longer used. 


CoachltemChildR 
eentrySeqDD 


String 


50 


When all the Child 
Coachltems in this 
CoachTopic have been used, 
they are restarted on the 
CoachltemChildReentrySeql 
D. If the 

CoachltemChildReentrySeql 
D = 0the Child half of the 
CoachTopic is expired and no 
longer used. 




RemediationTyp 
e 




SourceltemED 


Counter 




Unique key for this table 


Sourceltem 


String 


50 


Name of this Object 


SourceltemDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation reports 


SourceltemText 


String 


50 


String that Can be 1 
dynamically embedded into 
feedback text using Parameter 
Substitution Language (PSL) 




Coachltem 




SourceltemED 


Counter 




Unique key for this table 


Sourceltem 


String 


50 


Name of this Object 


SourceltemDesc 


String 


255 


Documentation String that 
appears with this object in 
auto-documentation reports 
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SourceltemText 


String 


50 


String that Can be 
dynamically embedded into 
feedback text using Parameter 
Substitution Language (PSL) 





Source Code In Accordance With A Preferred Embodiment 

lllllllllllllllllllllllllllllllllllllllllllillllllllllllllllllllllllllllllllllllllllllll 
II tutxport.h 

5 

llllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 

II Control Functions 

/* 

hh , _ ^ ... .. 

sjc sjc 5§c *jc ?|c sfc *{c j|c *|c *Jc sjc sjc s|£ s|> s|c jjc jJc sfs *$c #|c *|c jjc «{c tjc jj> j|c ?{c *|C sjc 



If 10 


* Name: 


TuResumeStudent 




* Purpose: 


To Resume a Student In progress. 


•r 1 

:f 


* Author: 


Mike Smialek / Andersen Consulting 


¥ 1 


* Input 




is 


* Parameters: 


long StudentID 




* 
* 


The Unique ID of the Student to load 




* 


long TaskID 




* 


The Unique ID of the Task to Load 


20 




int fromSubmissionSeqlD 






The Submission from which the Student continues the Task 




* 


<0 :Resume Task from latest submission 






=0 .-Restart Task 




* 


>0 :Continue from a specific submission 


25 








* Output 






* Parameters: 


none 
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* Function Return 



* Variables: TUT_ERR_DB_COULDNT_OPEN_D AT ABASE 





"FT TT 


T?r> o T\f\r< CCW TT F\NTT T HAH TAQF nflf 




TT TT 
1 U 1 


TJT?D T C\Y\ MA AA A AUTADTAO T7 AT TNm 




TT TT 
1 U 1 


T?r>T? t rxr\ xta a a a auttpa/t c t?at txth 




TT TT 
1U1 


T7T>T> T AT\ \TA PA A PUCC T7AT TXTT\ 

bRR_LUD_NU_CUACHbb _r UUINU 




lUT 


T7T> t-> t /*"\T\ TvTA OAT TT> PUTTCA >TT A TJ PCTC T? AT "ETN"FT\ 

bRR_bOD_NO_bOURCbl 1 bM 1 ARub 1 IS r UUND 




TUT_ 


T?T»T» T AT\ \TA OAT TD rTC T7ATT\TT\ 

ERR_LOD JNU_SOURCES_F(J U ND 




1U1_ 


ERRLODN U bU URCEl 1 tMb_r (J U JN D 




1UT_ 


ERRLODN U_ 1 ARLrb 1 CjROUrb _r OU ND 




TUT 


ERR_LOD_NO_TARGETS_FOUND 




TUT 


ERRLODNOTARGETPAGESJFOUND 




TUT 


ERRLODNOTARGETGROUPTARGETSFOUND 




TUT 


ERR_LOD_NO_RULES_FOUND 


* 


TUT 


ERR_DB_COULDNT_OPEN_RECORDSET 




TUT 


ERROK 









* Notes: Loads from Database or Document based on values 

* of m_StorageTypeTask and m_StorageTypeStudent 

* 



*/ 

extern "C" 
{ 

long _export WINAPI TuResumeStudent(long StudentID, long TaskID, int 
fromSubmissionSeqlD ); // Resumes a Student's work for the Task at the specified Submission 
} 

extern "C" 
{ 
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long _export WINAPI TuLoadArchivedSubmissions(long StudentID, long TaskID, int 
fromSubmissionSeqlD, int toSubmissionSeqID); // Loads Archived Submissions For a 
Student's work in a Task 

} 

5 

extern "C" 

{ 

long export WINAPI TuUseArchivedSubmissions(int n); // Replays n Archived 

submissions for debugging 
10 } 

extern "C" 
{ 

\t long _export WINAPI TuSaveCurrentStudent(); // Saves Current Student's work to DB 

!p"j{ 

15 15 } 

m 

Pj extern "C" 

m ^ 

I ( ^ng _export WINAPI TuSimulateStudent(long StudentID, long TaskID, float Intelligence, 

20 float Tenacity, int MaxTurns); // Not operational 

m ] 

9 

extern "C" 

{ 

25 long export WINAPI TuWriteUserDebugInfo(); // writes active CoachTopics to DB for 

Debugging 
} 

extern "C" 
30 { 

long export WINAPI KillEngine( long ITaskID); // Delete all Dynamic objects before 

shutdown 
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5 * Name: LoadTasklnfo 

* Purpose: To load data for a Task only. Student data is not loaded 

* Author: Mike Smialek / Andersen Consulting 

* Input 

* Parameters: long TaskED 

1 0 * The Unique ID of the Task to Load 

* Output 

* Parameters: none 



P. I 



* Function Return 

15 * Variables: TUT_ERR_DB_COULDNT_OPEN_D AT ABASE 

* TUTERRDOCCOULDNTLOADTASKDOC 

* TUT_ERR_LOD_NO_COACHTOPICS_FOUND 

* TUTERRLODNOCOACHITEMSFOUND 
? * TUT_ERR_LODJ^O_COACHES_FOUND 

H 20 * TUT^PJl_LOD_NO_SOURCEITEMTARGETS^FOUND 

* TUT_ERR_LOD_NO_SOURCES_FOUND 

* TUT_ERR_LOD_NO_SOURCEITEMS_FOUND 

* TUT_ERR_LOD_NO_TARGETGROUPS_FOUND 

* TUT_ERR_LOD_NO_TARGETS_FOUND 
25 * TUT_ERR_LOD_NO_TARGETPAGES_FOUND 

* TUTERRLODNOTARGETGROUPTARGETSFOUND 

* TUT_ERR_LOD_NO_RULES_FOUND 

* TUTERRDBCOULDNTOPENRECORDSET 

* 

30 * TUT_ERR_OK 

* Notes: 
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*/ 

extern "C" 
{ 

long export WESTAPI LoadTaskInfo( long ITaskID ); // Clear and (re)load info for TaskID 

5 } 



/* 



10 


* Name: 


TuLoadTaskDoc 




* Purpose: 


Loads a Tutor Document containing Task Data 




* Author: 


Mike Smialek / Andersen Consulting 




* Input 






* Parameters: 


long ITaskID 


15 


* 


TaskID To Load 




* Output 






* Parameters: 


none 




* Function Return 


20 


* Variables: 


TUT__ERR_DOC_COULDNT_LOAD_TASK_DOC 




* 


TUT_ERR_LOD_NO_COACHTOPICS_FOUND 




* 


TUT_ERR__LOD_NO_COACHITEMS_FOUND 




* 


TUT_ERR_LOD_NO_COACHES_FOUND 




* 


TUTERR JLODNOS OURCEITEMT ARGETSFOUND 


25 


* 


TUT_ERR_LOD_NO_SOURCES_FOUND 






TUTERRLODNOSOURCEITEMSFOUND 




* 


TUT_ERR_LOD_NO_TARGETGROIJPS_FOUND 




* 


TUTERRLODNOTARGETSFOUND 




* 


TUTJERRLODNOTARGETPAGESFOUND 


30 




TUT_ERRLOD_NO_TAJRGETGROUPTARGETS_FOUND 




* 


TUTJERRLODNORULESFOUND 




* 
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* TUT_ERR_OK 
* 

* Notes: TaskID is used to format the file name of the Document. 

^ ***************************************** 
*/ 

extern "C" 
{ 

long _export WINAPI TuLoadTaskDoc( long lTaskDD ); // Clear and (re)load info for 
1 0 TaskID from TaskDoc 
} 



/* 

€3 

Q 1 5 * Name: TuSaveTaskDoc 

|^ * Purpose: Saves The Task data as a Tutor Document 

* Input 



m 

m * Parameters: long ITaskID 



i * TaskID To Save 

U 

U 20 * Output 

H * Parameters: none 



25 



* Function Return 

* Variables: TUT_ERR_DOC_COULDNT__SAVE_TASK_DOC 

* 

* TUTERROK 

* Notes: TaskID is currently only used to format the file name of the Document. 

* If a TaskID is passed in that is different than the loaded Task, 
30 * it will save the loaded data as if it were data for Task ID 

*/ 
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extern "C" 
{ 

long _export WINAPI TuSaveTaskDoc( long ITaskID ); // Save info for TaskE) into 
TaskDoc 
} 



/* 



j|% 5§C jj|C r$C j|» 5{C jj? jj* sjs jjc jjc 2$C 5|> 5j* 5|C 3§C *(C 2$C 2|C *|C 5[C 5$C j}C 5jC 5|C Sji 5^5 *{> 5j% Sjt 2$* Sjc *fc 



* Name: 

* Purpose: 

* Input 

* Parameters: 

* 

* Output 

* Parameters: 



TuGo 

Kicks off Submission or Secret Submission 

long ICoachID 
CoachID submitting to 
>0 :Submit to Specific Coach 
=0 : Secret Submission to all Coaches 

none 



* Function Return 

* Variables: TUT ERR OK 

* Notes: 

*/ 

extern "C" 
{ 

long _export WINAPI TuGo( long ICoachID ); // kick off algorithm 

} 



* Name: TuIsDirty 
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* Purpose: 

* Input 

* Parameters: 

* 

* Output 

* Parameters: 



Gets the Dirty Status of the Task or of an individual Coach 

long ICoachID 
CoachDD for which to determine Dirty Status 
>0 determines Dirty Status for specific Coach 
=0 determines Dirty Status for whole Task 



LPINT IsDirty 

TRUE indicates this Coach or Task is Dirty 
FALSE indicates this Coach or Task is not Dirty 
If one or more Coaches is dirty the Task is Dirty 

* Function Return 

* Variables: TUT_ERR_LOD_NO__COACHES^FOUND 

* TUT_ERR_LOD_COACHD3_NOT_FOUND 

* TUTERROK 

* Notes: 

#####*###*##***###*********************** 

*/ 

extern "C" 
{ 

long _export WINAPI TuIsDirty(long TaskID, long ICoachID, LPINT IsDirty ); 

} 



***************************************** 



* Name: 

* Purpose: 

* Author: 

* Input 

* Parameters: 

* 

* Output 

* Parameters: 



TuGetSubmissionSeqID 

Returns the current SubmissionSeqID 

Mike Smialek / Andersen Consulting 

long TaskID 

The TaskID for which you want the SubmissionSeqID 
none 
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* Function Return 

* Variables: SubmisisonSeqID of the current Submission 

* 

5 * Notes: 

*/ 

extern "C" 
{ 

10 long _export WINAPI TuGetSubmissionSeqID(long TaskID); 
} 

/* 

* Name: TuGetFeedbackPrevCoachID 

* Purpose: Returns the CoachID of The Coach That delivered the previous feedback 

* Function Return 

* Variables: CoachID of The Coach That delivered the previous feedback 

* Notes: 

*/ 

extern "C" 
{ 

long _export WINAPI TuGetFeedbackPrevCoachE)(); 

} 

/* 

jfc j|C 5$C jjc J^C ij> 5jc Sj* S$C ?jc ?Jj 3[c 5$C 3$C 5jc j|> 3jc 2$C 3fc J^ji 5§C 5{C i|C 5|C 5{C 5$C 5fC l^C 

* Name: TuGetApprovalStatus 

30 * Purpose: Gets the Approval Status of the Task or of an individual Coach 

* Input 

* Parameters: long ICoachID 
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m 



CoachID for which to determine Approval 
>0 determines approval for specific Coach 
=0 -.Determines approval for whole Task 



* Output 

5 * Parameters: LPINT ApprovalRequired 

* TRUE indicates this Coach or Task requires approval 

* FALSE indicates this Coach or Task does not require approval 

* (Always TRUE when input CoachID = 0) 

10 * LPINT Approved 

* TRUE indicates this Coach or Task is approved 

* FALSE indicates this Coach or Task is not approved 

* Function Return 

15 * Variables: TUT_ERR_LOD_NO__COACHES_FOUND 

* TUTERRLODCOACHID NOT FOUND 



* TUT_ERR_OK 

* 



H 20 * Notes: 



***************************************** 
*/ 

extern "C" 
{ 

25 long _export WINAPI TuGetApprovalStatus( long ICoachID, LPINT ApprovalRequired, 
LPINT Approved ); // return approval status for CoachID 
} 

/* 

**********************************##****# 
30 * Name: TuCanProceed 

* Purpose: Determines if Task is in state in which user can proceed to another Task 

* Input 
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* Parameters: 

* Output 

* Parameters: 



long ITaskID 
TaskID to examine 



LPINT CanProceed 

* TRUE indicates user can proceed from this Task 

* FALSE indicates user can not proceed from this Task 

* Function Return 

* Variables: TUT ERR LOD NO COACHES FOUND 



10 



wis 

fi 



* TUT_ERR_OK 

* Notes: 

*/ 

extern "C" 



{ 



long _export WINAPI TuCanProceed( long ITaskID, LPINT CanProceed ); 



} 



Sjc if; s{i 3}; ?{c s|c sjs s|s sfs 2{f sfs s^c >|t s|s s^c 5|c s{c ^! ijs sjc s|s sjc ^5 2^5 sjc s{s 



TuMenu 

Opens Menu Dialog 
Mike Smialek / Andersen Consulting 



;20 *Name: 
I * Purpose: 

* Author: 

* Input 

* Parameters: 
25 * Output 

* Parameters: 

* Function Return 

* Variables: TUT_ERR_OK 

* Notes: 

*/ 

extern "C" 



none 



none 
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{ 

long __export WEMAPI TuMenuQ; 

} 

5 /* 

***************************************** 

* Name: TuTesterComment 

* Purpose: Opens Tester Comment Dialog 

* Input 

10 * Parameters: none 

* Output 

* Parameters: none 

* Function Return 

jJJ * Variables: TUT ERR OK 

Ol5 * Notes: 

m 

]Z ***************************************** 

V4 */ 

Wl extern "C" 

I* 20 long _export WIN API TuTesterCommentO; 

8 } 

p. 

IlllllllilllllllllllilllllllllllllllllllllllllllilllllillW 
llllllilllllllllllllllillllllllllillllllllllllllllllllllM 

25 // Notification Functions 

/* 

***************************************** 

* Name: TuCreateMap 

* Purpose: To Create an association between a Sourceltem and a Target 
30 * with a modifying Attribute value 

* Input 

* Parameters: long SIID 



120 



I 

AND1P045.P 



J J 



* SourceltemID of existing association to create 
* 

* long TED 

* TargetID of association to create 
5 * 

* double Attr 

* Attribute value of association to create 
* 

* Output 

10 * Parameters: none 

* 

* Function Return 

* Variables: TUT ERR TUF USIT TARGET NOT FOUND 
I * TUT ERR TUF USIT DUPLICATE FOUND 



W i z * 

Q 

§3 * TUT_ERR_OK 

%t * Notes: 

Ui 

|if ***************************************** 



*/ 

£20 extern "C" 

I { . 

long _export WIN API TuCreateMap( long SIID, long TID, double Attr ); 

} 



25 /* 

***************************************** 

* Name: TuModifyMap 

* Purpose: To Modify an association between a Sourceltem and a Target 

* with a new modifying Attribute value 
30 * Input 

* Parameters: long SIID 

* SourceltemID of existing association to Modify 
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* long TID 

* TargetID of existing association to Modify 

* double Attr 

* New Attribute value for association 

* Output 

* Parameters: none 

* Function Return 

* Variables: TUT_ERR_TUF_USIT_TARGET_NOT_FOUND 

* TUT_ERR_TUF_USIT__DUPLICATE_FOUND 

* TUTERROK 

* 

* Notes: This function calls TuDeleteMap / TuCreateMap 

* 

***************************************** 

*/ 

extern "C" 
{ 

long _export WINAPI TuModifyMap( long SIID, long TID, double Attr ); 

} 

/* 

st» -J* *1p »1# »1» «J> *U *1* *1* »1* *1» ^^^^^rl**l^^^^^i*^^^*^^^^iSe 

^> 2j> ?J> Vf» ijC 5J> ^f* *J> -T" *J> -T* ^f* ^ *X» •■p' "T* *T* *T* *♦* "** *** "T* *F* *T* 

* Name: TuDeleteMap2 

* Purpose: To Delete an association between a Sourceltem and a Target 

* Input 

* Parameters: long SIID 

* SourceltemID of association to delete 

* 

* long TED 

* TargetID of association to delete 
* 
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* double Attr 

* Attribute value of association to delete 

* Output 

* Parameters: none 

* Function Return 

* Variables: TUT ERR TUF USIT TARGET NOT FOUND 

* TUT_ERR_TUF_USIT_NOT_FOUND 
* 

* TUT_ERR_OK 

* 

* Notes: This function ignores the Attribute value and calls 

* TuDeleteMap( long SIID, long TED ) 

***************************************** 

*/ 

extern "C" 

{ 

long _export WDSfAPI TuDeleteMap2( long SIID, long TID, double Attr ); 

} 

/* 

***************************************** 

* Name: TuDeleteMap 

* Purpose: To Delete and association between a Sourceltem and a Target 

* Input 

* Parameters: long SIID 

* SourceltemID of association to delete 

* 

* long TID 

* TargetID of association to delete 

* 

* Output 

'* Parameters: none 
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* Function Return 

* Variables: TUT_ERR_TUF_USIT_TARGET_NOT_FOUND 

* TUT_ERR_TUF_USIT_NOT_FOUND 
5 * TUTERROK 

* Notes: 

***************************************** 

*/ 

extern *'C" 
10 { 

long _export WINAPI TuDeleteMap( long SIID, long TK> ); 

} 

llllllllllllllllllllllllllilllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll 
15 llllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllilllllllllllll 
II Configuration Functions 
/* 

ij ; ss; ***************************************** 

! * Name: TuSetODBCConnect 

p 20 * Purpose: To set ODBC Connect String for the Task Data Database 



* 



Input 



fc3 * Parameters: LPCSTR ODBCConnect 

* ODBC Connect String for the Task Data Database 

* Output 

25 * Parameters: none 

* 

* Function Return 

* Variables: TUT_ERROK 
* 

30 * Notes: 

*/ 
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extern "C" 
{ 

long _export WINAPI TuSetODBCConnect( LPCSTR ODBCConnect ); 

} 

5 

/* 

***************************************** 

* Name: TuSetODBCConnectTrack 

* Purpose: To set ODBC Connect String for the Student Tracking Database 
10 * Input 

* Parameters: LPCSTR ODBCConnect 

* ODBC Connect String for the Student Tracking Database 

* Output 

fj * Parameters: none 

0 15 * Function Return 

|j * Variables: TUT ERR OK 

* Notes: 

***************************************** 

*/ 

|=i 20 extern "C" 

1 { 

O long _export WINAPI TuSetODBCCormectTrack( LPCSTR ODBCConnect ); 

} 



25 /* 

***************************************** 

* Name: TuSetTaskDocPathName 

* Purpose: To set path and name of the Task Document file 

* Input 

30 * Parameters: LPCSTR fhm 

* Path and name of the Task Document file 

* Output 
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* Parameters: none 
* 

* Function Return 

* Variables: TUT ERR OK 
5 * 

* Notes: 

***************************************** 

*/ 

extern "C" 
10 { 

long _export WINAPI TuSetTaskDocPathName( LPCSTR fhm ); 

} 

/* 

H ***************************************** 

015 *Name: TuSetFeedbackFileName 

m * Purpose: To set path and name of file to use for holding feedback 
:;f * Input 

m * Parameters: LPCSTR fhm 

* Path and name of file to use for holding feedback 
U 20 * Output 

Tm * Parameters: none 

fj * 

* Function Return 

* Variables: TUT ERR OK 
25 * 

* Notes: 

***************************************** 

*/ 

extern "C" 
30 { 

long _export WINAPI TuSetFeedbackFileName( LPCSTR fhm ); 

} 
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10 



m Id 
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* Name: TuSetFeedbackPrevFileName 

* Purpose: To set path and name of file to use for holding previous feedback 

* Input 

* Parameters: LPCSTR fhm 

* Path and name of file to use for holding previous feedback 

* Output 

* Parameters: none 

* Function Return 

* Variables: TUTJERROK 

* Notes: 

*/ 

extern "C" 
{ 

long _export WINAPI TuSetFeedbackPrevFileName( LPCSTR fhm ); 



p 20 /* 



* Name: 

* Purpose: 

* Input 

* Parameters: 

* Output 

* Parameters: 



TuSetLogFileName 

To set path and name of file to use for full logging 

LPCSTR fhm 
Path and name of file to use for full logging 

none 



30 * Function Return 

* Variables: TUTJERROK 

* Notes: 
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***************************************** 

*/ 

extern "C" 
{ 

long _export WINAPI TuSetLogFileName( LPCSTR fhm ); 

} 

/* 

j|> jj* sj> sj* sjc s{c sjc *|c *jc #Jc j|c #5* ^j* *H *K *l* *i* *i* *fc *H *H *fc *H *fc 4* 



* Name: 

* Purpose: 

* Input 

* Parameters: 

* 

* Output 

* Parameters: 



TuSetLogLoadFileName 

To set path and name of file to use for load logging 

LPCSTR fhm 
Path and name of file to use for load logging 

none 



* Function Return 

* Variables: TUTJERRJ3K 
* 

* Notes: 

*/ 

extern "C" 



{ 



long _export WINAPI TuSetLogLoadFileName( LPCSTR fhm ); 



} 



* Name: 

* Purpose: 

* Input 



TuSetLogStudentFileName 

To set path and name of file to use for student logging 
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* Parameters: LPCSTR fhm 

* Path and name of file to use for student logging 

* Output 

* Parameters: none 

* Function Return 

* Variables: TUT ERR OK 

* 

* Notes: 

*/ 

extern "C" 
{ 

long _export WINAPI TuSetLogStudentFileName( LPCSTR fhm ); 

} 

/* 

* Name: TuSetLogSubmissionFileName 

* Purpose: To set path and name of file to use for submission logging 

* Input 

* Parameters: LPCSTR fhm 



Path and name of file to use for submission logging 



* Output 

* Parameters: none 

* Function Return 

* Variables: TUTJ3RROK 

* Notes: 
*/ 
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extern "C" 
{ 

long _export WINAPI TuSetLogSubmissionFileName( LPCSTR fiim ); 

} 

/* 

^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ %±+ ^ ^ ^ ^ ^ ^ & ^ ^ ^ ^ ^ ^ ^ "Xt «Jr ^^Slr^^^itf^f^^^If^Jf 
JJS Pfi 5}C 5|C ?p 5j£ Jj^ vj* *fr ?f» ^ *r* -Tr ■'v* ■t^ ^r* ^r* *T* *** %^ *X* *I* *T* *T" "v* *t* 

* Name: TuSetLogErrFileName 

* Purpose: To set path and name of file to use for error logging 

* Input 

* Parameters: LPCSTR fhm 

* Path and name of file to use for error logging 

* Output 

* Parameters: none 

* 

* Function Return 

* Variables: TUT ERR OK 

* Notes: 

************* ****************** 

*/ 

extern "C" 

{ 

long _export WINAPI TuSetLogErrFileName( LPCSTR fhm ); 

} 

/* 

* Name: TuSetTrace 

* Purpose: To turn Trace on and off 

* Input 

* Parameters: int TraceStatus 

* TUT TRACE ON :Tum Trace On 
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* TUTTRACEOFF :Turn Trace Off 

* Output 

* Parameters: none 

5 * Function Return 

* Variables: Previous Trace Status Value 

* TUT_TRACE_ON 

* TUT_TRACE_OFF 

10 * TUT_ERR_INVALID_TRACE_STATUS 

* Notes: 

*/ 

extern "C" 
1 15 { 

m lon § _export WINAPI TuSetTrace( int TraceStatus ); 

| 1 

U 1 

20 * Name: TuSetTrack 

* Purpose: To turn Tracking on and off. While tracking is on 

is? s 

O * all work the user does and all feedback the user receives 

* is kept. While Tracking is off only the most recent work is kept. 

* Input 

25 * Parameters: int TrackStatus 

* TUTTRACKON :Turn Tracking On 

* TUTJTRACKJ3FF :Turn Tracking Off 

* Output 

* Parameters: none 
30 * Function Return 

* Variables: Previous Trace Status Value 

* TUT TRACK ON 
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* TUTTRACKOFF 

* TUT ERR INVALID_TRACK_STATUS 

* Notes: 

***************************************** 



*/ 

extern "C" 
{ 

long _export WINAPI TuSetTrack( int TrackStatus ); 

10 } 

/* 

* Name: TuSetShowExceptionPopup 

1 

g 1 5 * Purpose: To Exception popups on and off. 



* Input 

* Parameters: int PopupStatus 

* TUT JPOPUP_ON :Turn Exception popups On 
f * TUTPOPUPOFF :Turn Exception popups Off 
U 20 * Output 

* Parameters: none 

■fas? 

* Function Return 

* Variables: Previous Exception popup Status Value 
25 * TUT_POPUP_ON 

* TUT_POPUP_OFF 

* 

* TUT_ERRJNVALID_POPUP_STATUS 

* Notes: 

*/ 

extern "C" 
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{ 

long export WINAPI TuSetShowExceptionPopup( int PopupStatus ); 

} 

5 /* 

* Name: TuSetStorageType 

* Purpose: To Direct Task and Student data to be loaded and saved 

* using a Document or Database 
10 * Input 

* Parameters: long StorageTypeTask 

* TUT STORAGE TYPE DOCUMENT :Load and Save Task Data using 
Document 

fj * TUT_STORAGE_TYPE_D AT ABASE :Load and Save Task Data using 
0 1 5 Database 

Jv s * long StorageTypeStudent 

Si * TUT_STORAGE_TYPE DOCUMENT :Load and Save Student Data using 
: Document 

H 20 * TUT_STORAGEJTYPE_DATABASE :Load and Save Student Data using 
S Database 



I * Output 

* Parameters: none 

* 

25 * Function Return 

* Variables: TUT_ERR_INVALID_STORAGE_TYPE_TASK 

* TUT_ERR_INVALID_STORAGE_TYPE_STUDENT 

* TUTERROK 
30 * Notes: 

***************************************** 

*/ 
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extern "C" 
{ 

long export WINAPI TuSetStorageType( int StorageTypeTask, int StorageTypeStudent ); 

} 

5 iiililllililitlltllliiillliillililllltiilllltllilllililiiiiltillllllllliilllllilllllilil 
IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIItlllllllllllllllllllllM 

Simulation Engine 

The idea is for the designer to model the task that he wants a student to accomplish using an 
10 Excel spreadsheet. Then, have an algorithm or engine that reads all the significant cells of the 
spreadsheet and notifies the Intelligent Coaching Agent with the appropriate information 
(SourceltemID, TargetID and Attribute). This way, the spreadsheet acts as a central repository 
for student data, contains most of the calculations required for the task and in conjunction with 
the engine handles all the communication with the IC A. The task is self contained in the 
Q 15 spreadsheet, therefore the designers no longer need a graphical user interface to functionally test 
S their designs (smart spreadsheet). Figure 40 is a block diagram illustrating how the simulation 

fy engine is architected into a preferred embodiment of the invention. 

u \ 
m 

Once the model and feedback for it are completely tested by designers, developers can 
hk 20 incorporate the spreadsheet in a graphical user interface, e.g., Visual Basic as a development 
f£ platform. The simulation spreadsheet is usually invisible and populated using functions provided 
p by the engine. It is very important that all modifications that the ICA needs to know about go 
through the engine because only the engine knows how to call the ICA. This significantly 
reduced the skill level required from programmers, and greatly reduced the time required to 
25 program each task. In addition, the end-product was less prone to bugs, because the tutor 

management was centralized. If there was a tutor problem, we only had to check on section of 
code. Finally, since the simulation engine loaded the data from a spreadsheet, the chance of data 
inconsistency between the tutor and the application was nil. 



30 
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Object Model 

Figure 41 is a block diagram setting forth the architecture of a simulation model in accordance 
with a preferred embodiment. The Simulation Object Model consists of a spreadsheet model, a 
spreadsheet control object, a simulation engine object, a simulation database, input objects, 
5 output objects, list objects and path objects. 

Spreadsheet object 

The first object in our discussion is the Spreadsheet object. The Spreadsheet is the support for 
all simulation models. A control object that is readily integrated with the Visual Basic 
1 0 development plat. The control supports printing and is compatible with Microsoft Excel 
spreadsheets. With that in mind, designers can use the power of Excel formulas to build the 
simulation. The different cells contained in the spreadsheet model can be configured as Inputs, 
Outputs or Lists and belong to a simulation Path. 
■J-,* Input object 

p 15 All cells in the spreadsheet that need to be manually entered by the designer or the student via 
X the GBS application are represented by input objects. Every input has the following interface: 



Field Name 


Data Type 


Description 


InputE) 


long 


Primary Key for the table 


TaskID 


long 


TaskID of the task associated with the 
input 


PathID 


long 


PathID of the path associated with the 
input 


InputName 


string* 50 


Name of the input 


InputDesc 


string*255 


Description of the input 


ReferenceName 


string* 50 


Name of the spreadsheet cell associated 
with the input 


TutorAware 


boolean 


Whether the ICA should be notified of 
any changes to the input 


SourceltemID 


long 


SourceltemID if input is a distinct input 
0 if input is a drag drop input 


Target© 


long 


TargetED of the input 


Row 


long 


Spreadsheet row number of the input -> 
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speed optimization 


Column 


long 


Spreadsheet column number of the input 
-> speed optimization 


SheetName 


string* 50 


Sheet name were the input is located -> 
speed optimization 



This information is stored for every input in the Input table of the simulation database 
(ICASim.mdb). Refer to the example below. 



5 When designers construct their simulation model, they must be aware of the fact that there are 2 
types of Inputs: 

1. Distinct Input 

2. Drag & Drop Input 

%:h 
;F~; 

I! S 
~; 

MlO Distinct Input 

§3 The Distinct Input consists of a single spreadsheet cell that can be filled by the designer at design 
|J time or by the GBS application at run time via the simulation engine object's methods. The 
tjl purpose of the cell is to provide an entry point to the simulation model. This entry point can be 
for example an answer to a question or a parameter to an equation. If the cell is TutorAware (all 
1 5 inputs are usually TutorAware), the ICA will be notified of any changes to the cell. When the 
Jjl ICA is notified of a change two messages are in fact sent to the ICA: 

'f if? 1. An ICANotifyDestroy message with the input information i.e., SourceltemID, TargetID and 
null as Attribute. This message is to advise the ICA to remove this information from its 
memory. 

20 2. An ICANotifyCreate message with the input information i.e., SourceltemID, TargetID, 

Attribute (cell numeric value) . This message is to advise the ICA to add this information to its 
memory. 

A Distinct Input never requires that a user answer a mathematics question. These are the steps 
25 required to configure that simulation. Figure 42 illustrates the arithmetic steps in accordance 
with a preferred embodiment. 

1. Define a name for cell C2 in Excel. Here we have defined "Distinct_Input'\ 
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2. In the ICA, define a task that will be assigned to the simulation. Ex: a TaskID of 123 is 
generated by the ICA. 

3. In the ICA, define a Target for the input. Ex: a TargetID of 4001 is generated by the ICA. 

4. In the ICA, define a Sourceltem for the input. Ex: a SourceltemID of 1201 is generated by 
the ICA. 

5. Associate the input to a path (refer to Path object discussion). 

6. Add the information in the Input table of the simulation engine database. 



A record in an Input table is presented below. 



InputDD: 


12345 


TaskID: 


123 


PathID: 


1234 


InputName: 


Question 1 input 


InputDesc: 


Distinct input for Question 1 


ReferenceName: 


Distinctlnput 


TutorAware: 


True 


SourceltemID 


1201 


TargetID: 


4001 


Row: 


2 


Column: 


3 


SheetName: 


Sheetl ' 



The Row, Column and SheetName are filled in once the user clicks "Run Inputs/Outputs". The 
simulation engine decodes the defined name (Reference Name) that the designer entered, and 
populates the table accordingly. This is an important step. We had several occasions when a 
designer would change the layout of a spreadsheet, i.e., move a defined name location, then 
forget to perform this step. As such, bizarre data was being passed to the tutor; whatever data 
happened to reside in the old row and column. Once the configuration is completed, the 
designer can now utilize the ICA Utilities to test the simulation. 
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Drag & Drop Input 

The drag & drop input consist of two consecutive spreadsheet cells. Both of them have to be 
filled by the designer at design time or by the GBS application at run time via the simulation 
engine object's methods. This type of input is used usually when the user must choose one 
5 answer among a selection of possible answers. Drag & drop inputs are always TutorAware. The 
left most cell contains the SourceltemBD of the answer picked by the user (every possible 
answer needs a SourceltemID) and the rightmost cell can contain a numeric value associated to 
that answer. You need to define a name or ReferenceName in the spreadsheet for the rightmost 
cell. 

10 

ICA will be notified of any changes to either one of the cells. When the ICA is notified of a 
change two messages are in fact sent to the ICA: 

1. An ICANotifyDestroy message with the input information i.e., SourceltemID before the 
J* change occurred, TargetID of the input and the Attribute value before the change occurred. 

Q 15 2. An ICANotifyCreate message with the input information i.e., SourceltemID after the change 
I| occurred, TargetID of the input and the Attribute value after the change occurred. 

?? i 

m Let's demonstrate the use of a drag & drop input building on top of the previous example. Here, 
the user is asked to answer yet another mathematics question. These are the steps required to 

ft? 

U20 configure that section of the simulation. Figure 43 illustrates a drag & drop input operation in 

f i 

p accordance with a preferred embodiment. 

Q 1 . Define a name for cell CI 1 in Excel. Here we have defined "DragDropInput". 

La. 

2. Let's use the same TaskID as before since Question 2 is part of the same simulation as 
Question 1. Ex: TaskID is 123. 

25 3. In the ICA, define a Target for the input. Ex: a TargetID of 4002 is generated by the ICA. 

4. In the ICA, define a Sourceltem for every possible answer to the question. Ex: 
SourceltemEDs 1202 to 1205 are generated by the ICA. 

5. Associate the input to a path (refer to Path object discussion). 

6. Add the information in the Input table of the simulation engine database. 

30 

A record in the Input table in accordance with a preferred embodiment is presented below. 
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InputID: 


12346 


TaskID: 


123 


PathID: 


1234 


InputName: 


Question 2 input 


InputDesc: 


Drag & Drop input for Question 2 


ReferenceName: 


DragDropInput 


Tutor Aware: 


True 


SourceltemE) 


O *** 


TargetID: 


4002 


Row: 


11 


Column: 


3 


SheetName: 


Sheetl 
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List object 

Figure 44 illustrates list object processing in accordance with a preferred embodiment. The list 
object consists of one cell identifying the list (cell #1) and a series of placeholder rows 
resembling drag & drop inputs (cells #1.1 - l.n to cells #n.l- n.n). The list is used usually when 
the user must choose multiple elements among a selection of possible answers. Cell #1 must 
have a uniquely defined name also called the list name. Cells #1.1 to #n.l can contain the 
SourceltemID of one possible answer picked by the user (every possible answer needs a 
SourceltemE)). The content of these cells must follow this format : -ListName-SourceltemlD. 
Cells #1.2 to #n.2 will hold the numeric value (attribute) associated with the SourceltemID in the 
cell immediately to the left. Cells #1.3 - l.n to #n.3 - n.n are optional placeholders for data 
associated with the answer. KEY NOTE: When implementing a list object the designer must 
leave all the cells under #n.l to #n.n blank because this range will shift up every time an item is 
removed from the list. 



Every list has the following interface: 



Field Name 


Data Type 


Description 


ListID 


long 


Primary Key for the table 
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TaskID 


long 


TaskID of the task associated with the 
list 


PathID 


long 


PathID of the path associated with the 
list 


ListName 


string* 50 


Name of the list 


ListDesc 


string*255 


Description of the list 


ReferenceName 


string*50 


Name of the spreadsheet cell associated 
with the list 


TutorAware 


boolean 


Whether the IC A should be notified of 
any changes to the list 


TargetID 


long 


TargetID of the output 


TotalColumns 


long 


Total number of data columns 


Row 


long 


Spreadsheet row number of the output 
-> speed optimization 


Column 


long 


Spreadsheet column number of the 
output -> speed optimization 


SheetName 


string* 50 


Sheet name were the input is located -> 
speed optimization 



Use of a list is demonstrated by continuing our math test. The math question in this example 
invites the user to select multiple elements to construct the answer. These are the steps required 
to configure that section of the simulation. Figure 45 illustrates the steps for configuring a 
5 simulation in accordance with a preferred embodiment. 

1 . Define a name for cell C23 in Excel. Here we have defined "The__List". 

2. Let's use the same TaskID as before since Question 3 is part of the same simulation as 
Question 1 and 2. Ex: TaskID is 123. 

3. In the ICA, define a Target for the list. Ex: a TargetID of 4006 is generated by the ICA. 
10 4. In the ICA, define a Sourceltem for every item that could be placed in the list. Ex: the 

following SourceltemlDs 1209, 1210, 1211, 1212, 1213, 1214 are generated by the ICA. 

5. Associate the list to a path (refer to Path object discussion). 

6. Add the information in the List table of the simulation engine database. 
A record in the List table in accordance with a 
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preferred embodiment is presented in the table 
appearing below. 



ListID: 


12346 


TaskID: 


123 


PathID: 


1234 


ListName: 


Question 3 list 


ListDesc: 


List for Question 3 


ReferenceName: 


TheJList 


TutorAware: 


True 


TargetID: 


4006 


TotalColumns: 


1 


Row: 


23 


Column: 


3 


SheetName: 


Sheetl 



Output object 

All cells in the spreadsheet that are result of calculations (do not require any external input) can 
be represented by output objects. Every output has an interface as outlined in the table below. 



Field Name 


Data Type 


Description 


OutputID 


long 


Primary Key for the table 


TaskID 


long 


TaskID of the task associated with the output 


PathID 


long 


PathID of the path associated with the output 


OutputName 


string*50 


Name of the output 


OutputDesc 


string*255 


Description of the output 


ReferenceName 


string*50 


Name of the spreadsheet cell associated with the 
output 


TutorAware 


boolean 


Whether the IC A should be notified of any changes 
to the output 


SourceltemTD 


long 


SourceltemID of the output 


TargetID 


long 


TargetID of the output 
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Row 


long 


Spreadsheet row number of the output -> speed 
optimization 


Column 


long 


Spreadsheet column number of the output -> speed 
optimization 


SheetName 


string*50 


Sheet name were the input is located -> speed 
optimization 
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All this information is stored for every output in the Output table of the simulation database 
(ICASim.mdb). When designers construct their simulation model, they must be aware of the fact 
that there is only 1 type of Outputs : the Distinct Output. 
Distinct Output 

A Distinct Output consists of one and only one spreadsheet cell that contains a formula or a 
result of calculations. The existence of Output cells is the main reason to have a simulation 
model. If the cell is TutorAware, the ICA will be notified of any changes to the cell when all 
outputs are processed otherwise the ICA will be unaware of any changes. When the ICA is 
notified of a change two messages are in fact sent to the ICA: 

L An ICANotifyDestroy message with the output information i.e., SourceltemID, TargetID and 
null as Attribute. This message is to advise the ICA to remove this information from its 
memory. 

2. An ICANotifyCreate message with the output information i.e., SourceltemID, TargetID, 
Attribute (cell numeric value) . This message is to advise the ICA to add this information to its 
memory. As opposed to Distinct Inputs and Drag & Drop Inputs which notify the ICA on every 
change, Distinct Outputs are processed in batch just before asking the ICA for feedback . 



To notify the ICA of the total dollar amount of the items in the list. We definitely need a 
20 Distinct Output for that. The output will contain a sum formula. Figure 46 illustrates a distinct 
output in accordance with a preferred embodiment. The steps required to configure that section 
of the simulation taking in consideration that the list is already configured are presented below. 

1 . Define a name for cell C24 in Excel. Here we have defined "Distinct_Output". 

2. Let's use the same TaskID as before since Question 3 is part of the same simulation as 
25 Question 1 and 2. Ex: TaskID is 123. 

3. In the ICA, define a Target for the output. Ex: a TargetID of 4005 is generated by the ICA. 
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4. In the IC A, define a Sourceltem for the output. Ex: a SourceltemED of 1215 is generated by 
thelCA. 

5. Associate the output to a path (refer to Path object discussion). 

6. Add the information in the Output table of the simulation engine database. 

A record in an Output table in accordance with a preferred embodiment is presented below. 



Output©: 


12347 


TaskID: 


123 


PathID: 


1234 


OutputName: 


Question 3 output 


OutputDesc: 


Distinct Output for Question 3 


ReferenceName: 


Distinct_Output 


Tutor Aware: 


True 


SourceltemID 


1215 


Target©: 


4005 


Row: 


24 


Column: 


6 


SheetName: 


Sheetl 



Path object 

Paths are used to divide a simulation model into sub-Simulations meaning that you can group 
certain inputs, outputs and lists together to form a coherent subset or path. Every path has the 
following interface: 



Field Name 


Data Type 


Description 


PathID 


long 


Primary Key for the table 


TaskID 


long 


TaskID of the task associated with the path 


PathNo 


long 


Numeric value associated to a path 


PathName 


string* 50 


Name of the path 


PathDesc 


string*255 


Description of the path 



All this information is stored for every path in the path table of the simulation database 
(ICASim.mdb). 
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Simulation Engine 

The simulation engine is the interface between the model, the simulation database and the 
Intelligent Coaching Agent. The simulation engine is of interest to the designer so that he can 
understand the mechanics of it all But it is the developer of applications using the engine that 
5 should know the details of the interface (methods & properties) exposed by the engine and the 
associated algorithms. 

Once the designer has constructed the simulation model (Excel Spreadsheet) and configured all 
the inputs, outputs & lists, he is ready to test using the test bench included in the ICA Utilities 
10 (refer to ICA Utilities documentation). The developer, in turn, needs to implement the calls to 
the simulation engine in the GBS application he's building. The following list identifies the 
files that need to be included in the Visual Basic project to use the simulation workbench : 



#5; 

fh 


wSimEng.cls 


Simulation Engine class 


•M 

•f : i 

Wl 


wSimEng.bas 


Simulation Engine module (this module was introduced 
only for speed purposes because all the code should 
theoretically be encapsulated in the class) 


m 


wConst.bas 


Intelligent Coaching Agent constant declaration 




wDeclare.bas 


Intelligent Coaching Agent DLL interface 




wlca.cls 


Intelligent Coaching Agent class 


im 

hh 


wlca.bas 


Intelligent Coaching Agent module (this module was 
introduced only for speed purposes because all the code 
should theoretically be encapsulated in the class) 



15 To have a working simulation, a developer places code in different strategic areas or stages of 
the application. There's the Initial stage that occurs when the form containing the simulation 
front-end loads. This is when the simulation model is initialized. There's the Modification 
stages that take place when the user makes changes to the front-end that impacts the simulation 
model. This is when the ICA is notified of what's happening. There's the Feedback stage when 

20 the user requests information on the work done so far. This is when the simulation notifies the 
ICA of all output changes. Finally, there's the Final stage when the simulation front-end 
unloads. This is when the simulation is saved to disk. 
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The different stages of creating a simulation, including the Visual Basic code involved, are 
presented below. 

5 Initial stage 

1. Creating the ICA & the simulation engine objects 

Code: 

Set moSimEngine = New classSimEngine 
Set moICA = New classICA 

10 

Description: The first step in using the simulation engine is to create an instance of the class 
classSimEngine and also an instance of the class classICA. Note that the engine and ICA should 
be module level object "mo" variables. 

13 15 2. Loading the simulation 

JX Code: 

m 

P J IRet - moSimEngine.OpenSimulation(App.Path & DIRDATA & FILE_SIMULATION, 

m Me.bookSimulation) 

U 

U 20 IRet - moSimEngine.LoadSimulation(mlICATaskID, App.Path & DIRD AT ABASE & 

| DBSIMULATION, 1) 

ri 

Description: After the object creation, the OpenSimulation and LoadSimulation methods of the 
simulation engine object must be called. The OpenSimulation method reads the specified Excel 
25 5.0 spreadsheet file into a spreadsheet control. The LoadSimulation method opens the 

simulation database and loads into memory a list of paths, a list of inputs, a list of outputs and a 
list of lists for the specific task. Every method of the simulation engine will return 0 if it 
completes successfully otherwise an appropriate error number is returned. 

30 3. Initializing and loading the Intelligent Coaching Agent 

Code: 
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IRet = moICA.Initialize(App.Path & T & App.EXEName & ".ini", App.Path & 
DIR_D AT ABASE, App.Path & DIRJCADOC, App.Path & T) 

IRet - moICA.LoadTask(mlICATaskID, ICAStudentStartNew) 

5 

Description: The simulation engine only works in conjunction with the ICA. The Initialize 
method of the ICA object reads the application .ini file and sets the Tutor32.dll appropriately. 
The LoadTask method tells the ICA (Tutor32.dll) to load the .tut document associated to a 
specific task in memory. From that point on, the ICA can receive notifications. 

10 

Note: The .tut document contains all the element and feedback structure of a task. Ex: 
SourcePages, Sourceltems, TargetPages, Targets, etc... 

u.. 

■* 4. Restoring the simulation 

Q 15 Code: 

£3 

|S «Code to reset the simulation when starting over» 

W «Code to load the controls on the simulation front-end» 

m IRet = moSimEngine.RunInputs(sPaths, True) 

!f IRet = moSimEngine.RunOutputs(sPaths, True) 

hk 20 IRet = moSimEngine.RunLists(sPaths, True) 

fi Call moICA.Submit(O) 

p Call moICA.SetDirtyFlag(0, False) 

Description: Restoring the simulation involves many things: 
25 • clearing all the inputs and lists when the user is starting over 

• loading the interface with data from the simulation model 

• invoking the Runlnputs, RunOutputs and RunLists methods of the simulation engine object in 
order to bring the ICA to it's original state 

• calling the Submit method of the ICA object with zero as argument to trigger all the rules 
30 • calling the SetDirtyFlag of the ICA object with 0 and false as arguments in order to reset the 

user's session. 
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Running inputs involves going through the list of TutorAware inputs and notifying the ICA of 
the SourceltemID, TargetID and Attribute value of every input. 

Running lists involves going through the list of TutorAware lists and notifying the ICA of the 
SourceltemID, TargetID and Attribute value of every item in every list. The TargetID is unique 
5 for every item in a list. 

Running outputs involves going through the list of TutorAware outputs and notifying the ICA of 
the SourceltemID, TargetID and Attribute value of every output. 

Modification stage 
10 1. Reading inputs & outputs 

Code: 

Dim sDataArray(2) as string 
Dim vAttribute as variant 
Dim ISourceltemID as long 
O 15 Dim ITargetID as long 

; ;;; :f? 

fU IRet = moSimEngine.ReadReference("Distinct_Input", vAttribute, ISourceltemID, ITargetID, 

m sDataArray) 

20 Description: The ReadReference method of the simulation object will return the attribute value 

7% of the input or output referenced by name and optionally retrieve the SourceltemID, TargetID 

O. and related data. In the current example, the attribute value, the SourceltemID, the TargetID and 
3 data cells will be retrieved for the input named Distinct_Input. 

25 2. Modifying distinct inputs 

Code: 

Dim vAttribute as variant 
Dim ISourceltemID as long 
Dim sDataArray(2) as string 

30 

vAttribute=9999 
sDataArray(0)="Data Cell #1" 
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sDataArray(l)="Data Cell #2" 
sDataArray(2)-"Data Cell #3" 

IRet = moSimEngine. WriteReference("Distinct_Input", vAttribute, , sDataArray) 

5 Description: Modifying a distinct input is as simple as calling the WriteReference method of the 
simulation object passing the input name, the new attribute value and optionally a data array. 
The simulation engine takes care of notifying the ICA of the change. 

3. Modifying drag&drop inputs 

10 Code: 

Dim vAttribute as variant 
Dim ISourceltemID as long 
Dim sDataArray(2) as string 

r !f s 

0 15 lSourceItemID=1202 

m vAttribute=9999 

5* sDataArray(0)="Data Cell #1" 

iyi sDataArray( 1 )="Data Cell #2" 

f sDataArray(2)="Data Cell #3" 

p 20 IRet = moSimEngine.WriteReference("DragDrop_Iiiput'', vAttribute, ISourceltemID, 
S sDataArray) 

Description: Modifying a drag&drop input is as simple as calling the WriteReference method of 
the simulation object passing the input name, the new attribute value, the new SourceltemID and 
25 optionally a data array. The simulation engine takes care of notifying the ICA of the change. 

4. Reading lists 

Code: 

IRet = moSimEngine.ListRead(sListName, IListlndex, vAttribute, ISourceltemID, ITargetID, 
30 sDataArray) 
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Description: All list in the simulation model can be read one item at a time using the ListRead 
method of the simulation engine object. Passing the list name and the index of the item to 
retrieve, the function will return the Attribute value and optionally the SourceltemID, TargetID 
and data array of the item specified. Use a looping structure to read entire lists into memory, or 
5 to search for and retrieve a particular line item. This will be done quite often as designers 
generally allow users to manipulate items from lists. For example, if a user begins to drag an 
element of a list, you will need to retrieve this data from the list item they are dragging. 

5. Modifying lists 

10 Code: 

IRet = moSimEngine.ListAdd(sListName, vAttribute, ISourceltemID, sDataArray) 
IRet = moSimEngine.ListCount(sListName, lTotalltems) 

IRet = moSimEngine.ListModify(sListName, IListlndex, vAttribute, lSourceltemED, 
sDataArray) 

Q 15 IRet = moSimEngine.ListDelete(sListName, IListlndex) 

:L.._5 

PJ Description: The simulation engine object provides basic functionality to manipulate lists. 

P 

m 

The ListAdd method appends an item(SourceltemE), Attribute, Data array) to the list. Let's 
fcfe 20 explain the algorithm. First, we find the top of the list using the list name. Then, we seek the 
SJ first blank cell underneath the top cell. Once the destination is determine, the data is written to 

itjj ji 

Q the appropriate cells and the ICA is notified of the change. 

;[ „ 

The ListCount method returns the number of items in the specified list. The algorithm works 
exactly like the ListAdd method but returns the total number of items instead of inserting another 
25 element. 

The ListModify method replaces the specified item with the provided data. Let's explain the 
algorithm. First, we find the top of the list using the list name. Second, we calculate the row 
offset based on the item number specified. Then, the ICA is notified of the removal of the 
30 existing item. Finally, the data related to the new item is written to the appropriate cells and the 
ICA is notified of the change. 
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The ListDelete method removes the specified item. The algorithm works exactly like the 
ListModify method but no new data is added and the cells (width of the list set by 'Total 
Columns') are deleted with the 'move cells up' parameter set to true. Keep this in mind, as 
designers often enter the wrong number of columns in the Total Columns parameter. When they 
5 overestimate the Total Columns, ListDelete will modify portions of the neighboring list, which 
leads to erratic behavior when that list is displayed. 

Feedback stage 

1. Running the simulation 

10 Code: 

IRet = moSimEngine.RunOutputs(sPaths, True) 

Description: Inputs and lists notify the ICA when changes happen but not outputs. Therefore, 
the RunOutputs method must be invoked before submitting the work for feedback. 



015 



m .2. Triggering the ICA Rule engine 

iff 



IV. Code: 

Si 

|l lRet= moICA.Submit(lCoachID) 

U 

¥ h 20 Description: Once the simulation has been processed, the Submit method of the ICA object must 

|| be called to trigger all the rules and deliver the feedback. This feedback will be written by the 

0 Tutor32.dll to two RTF formatted files. One file for previous feedback and one file for the 
current feedback. 

25 3. Displaying ICA feedback 

Code: 

Set oViewer = New CFeedbackViewer 
oViewer.CoachID = vlCoachED 
Call oViewer.DisplayFeedBack(moApp) 
30 Description: The only thing required to display feedback information is to have an RTF control 
on a form and read-in the feedback files produced by the Submit method of the ICA object. 
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Final stage 

1. Saving the simulation 

Code: 

5 IRet = moSimEngine.SaveSimulation(App.Path & DIRDATA & FILE_SIMULATION) 

Description: The SaveSimulation method of the simulation engine object will save the specified 
Excel spreadsheet to disk. 

1 0 SYSTEM DYNAMICS IN ACCORDANCE WITH A PREFERRED EMBODIMENT 

To use system dynamics models in the architecture, an engine had to be created that would 
translate student work into parameters for these models. A complex system dynamics model to 
interact with an existing simulation architecture is discussed below. The system dynamics model 
provides the following capabilities. 
3 15 1 . Allow designers to build and test their system dynamics models and ICA feedback before the 
real interface is built. 

2. Reduce the programming complexity of the activities. 

3. Centralize the interactions with the system dynamics models. 



f i? 20 System Dynamics Engine 

m As with the simulation engine, the designer models the task that he/she wants a student to 

W accomplish using a Microsoft Excel spreadsheet. Here, however, the designer also creates a 

H 

system dynamics model (described later). The system dynamics engine will read all of the 
significant cells within the simulation model (Excel) and pass these values to the system 
25 dynamics model and the ICA. After the system dynamics model runs the information, the output 
values are read by the engine and then passed to the simulation model and the ICA. 

Figure 47 is a block diagram presenting the detailed architecture of a system dynamics model in 
accordance with a preferred embodiment. Once the simulation model, system dynamics model 
30 and feedback are completely tested by designers, developers can incorporate the spreadsheet in a 
graphical user interface, e.g., Visual Basic as a development platform. Figure 47 illustrates that 
when a student completes an activity, the values are passed to the system dynamics engine where 
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the values are then passed to the system dynamics model (as an input), written to the simulation 
model and submitted to the ICA. When the system dynamics model is played, the outputs are 
pulled by the engine and then passed to the simulation model and the ICA. Note that the 
simulation model can analyze the output from the system dynamics model and pass the results of 
5 this analysis to the ICA as well. The simulation model can then be read for the output values and 
used to update on-screen activity controls (such as graphs or reports). 

It is very important that all modifications that the ICA and system dynamics model need to know 
about go through the engine because only the engine knows how to call these objects. This 
10 significantly reduces the skill level required from programmers, and greatly reduces the time 
required to program each task. In addition, the end-product is less prone to bugs, because the 
model and tutor management will be centralized. If there is a problem, only one section of code 
needs to be checked. Finally, since the engine loads the data from the spreadsheet, the chance of 

%' H data inconsistency between the ICA, the system dynamics model and the application is 

O 15 insignificant. 

ty Figure 48 is graphical representation of the object model which is utilized to instantiate the 

%k - 

m system dynamic engine in accordance with a preferred embodiment. The System Dynamics 

* . Object Model consists of a spreadsheet object, a system dynamics object, a simulation database, 
20 model objects, parameter input objects and parameter output objects. The first object in our 

J5 discussion is the Spreadsheet object. The Spreadsheet is the support for all simulation models. 

P The spreadsheet object is integrated with a Visual Basic development platform in accordance 
with a preferred embodiment. The control supports printing and is compatible with Microsoft 
Excel spreadsheets. With that in mind, designers can use the power of Excel formulas to build 
25 the simulation. These spreadsheets can sort or make calculations on the time interval data that is 
received from the system dynamics model, which allows the ability to show trends. This 
functionality allows a large amount of the calculations and number-crunching to occur in the 
spreadsheet and not in the code, placing more control with the activity designers. 

30 The different cells in the spreadsheet model can be configured as parameter inputs or parameter 
outputs for a system dynamics model. This is what the system dynamics engine uses to write 
and read data from the system dynamics model, pass values to the ICA and update the student's 
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work in the on-line activities. By making the spreadsheet object the central repository for the 
system dynamics data, we ensure that the system dynamics model, simulation model, activity 
and ICA are all in synch. 

5 The system dynamics model generates simulation results over time, based on relationships 
between the parameters passed into it and other variables in the system. A system dynamics 
object is used to integrate with Visual Basic and the spreadsheet object. The object includes 
logic that controls the time periods as well as read and write parameters to the system dynamics 
model. With Visual Basic, we can pass these parameters to and from the model via the values in 
1 0 the simulation obj ect . 

The system dynamics object also controls the execution of the system dynamics model. What 
this means is that after all of the parameter inputs are passed to the system dynamics model, the 
engine can run the model to get the parameter outputs. The system dynamics object allows for 

p 1 5 the system dynamics models to execute one step at a time, all at once, or any fixed number of 

X time periods. 

iw'S 

;.! ; J. 

p 

When the system dynamics model runs, each step of the parameter input and parameter output 
data is written to a 'backup' sheet for two reasons. First, the range of data that is received over 
frh 20 time (the model playing multiple times) can be used to create trend graphs or used to calculate 
J 5 ;!- statistical values. Second, the system dynamics model can be restarted and this audit trail of data 
Ip can be transmitted into the model up to a specific point in time. What this means is that the 
engine can be used to play a simulation back in time. 

25 When any event occurs within the system dynamics engine, a log is created that tells the 

designers what values are passed to the simulation model, system dynamics model and ICA as 
well as the current time and the event that occurred. The log is called "SysDyn.log" and is 
created in the same location as the application using the engine. As with the spreadsheet object, 
the system dynamics object allows a large amount of the calculations to occur in the system 

30 dynamics model and not in the activity code, again placing more control with the activity 
designers. 
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Model objects are used to configure the system dynamics models with regard to the time periods 
played. Models are what the parameter inputs and parameter outputs (discussed later) relate to, 
so these must be created first. Every model has the following application programming 
interface: 



Field Name 


Data Type 


Description 


ModellD 


Long 


Primary Key for the table 


TaskID 


Long 


TaskID of the task associated with the model 


ModelName 


String*50 


Name of the model (informational purposes) 


ModelDesc 


String*50 


Description of the model (informational 
purposes) 


SysDynModel 


String*50 


Filename of the actual system dynamics model 


Start 


Long 


Start time to play modal 


Stop 


Long 


Stop time to play model 


Step 


Long 


Interval at which to play one model step and 
record data 



This information is stored in the model table of the simulation database (ICASim.mdb). All of 
the values that will need to be manually entered by the student that are passed into the system 
dynamics model are configured as parameter inputs (PInputs) objects. 
Every PInput has an interface as detailed below. 



Field Name 


Data Type 


Description 


PinputID 


long 


Primary Key for the table 


TaskID 


long 


TaskID of the task associated with the 
parameter input 


ModellD 


long 


ID of the model associated with the 
parameter input 


InputName 


string*50 


Name of the parameter input (informational 
purposes) 


InputDesc 


string*255 


Description (informational purposes) 


ReferenceName 


string*50 


Name of the spreadsheet cell associated 
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with the parameter input 1 


SimReferenceName 


string* 50 


Name of the associated parameter in the 
system dynamics model 


TutorAware 


boolean 


Whether the ICA should be notified of any 
changes to the parameter input 


SourceltemID 


long 


SourceltemID of the parameter input 


TargetID 


long 


TargetID of the parameter input 


Row 


long 


Spreadsheet row number of the parameter 
input 

(used for speed optimization) 


Column 


long 


Spreadsheet column number of the 

parameter input 

(used for speed optimization) 


SheetName 


string*50 


Sheet name were the parameter input is 
located 

(used for speed optimization) 



All of this information is stored for every parameter input in the PInput table of the simulation 
database (ICASim.mdb). 

PInputs consist of one spreadsheet cell that can be populated by a designer at design time or by 
the GBS application at run time via the system dynamics engine object's methods. The purpose 
of the cell is to provide an entry point to the simulation and system dynamics models. An 
example of an entry point would be the interest rate parameter in the interest calculation 
example. The ICA is notified of any changes to the cell when an appropriate activity transpires. 
When the ICA is notified of a change two messages are sent to the ICA. The first is an 
ICANotifyDestroy message with the parameter input information i.e., SourceltemID, TargetID 
and null as an attribute. This message is sent to inform the ICA to remove information from its 
memory. The second message is an ICANotifyCreate message with the parameter input 



1 PowerSim allows designers to create parameters as arrays. If this is the case, then each array item 
MUST have one parameter input. What this means is that dynamics arrays can not be used by the System 
Dynamics engine. 
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information i.e., SourceltemID, TargetID, Attribute (cell numeric value). This message advises 
the ICA to add this information to its memory. 

To demonstrate the use of a parameter input, the interest rate calculation example is again used 
as a backdrop to illuminate various features. Figures 49 is a PInput Cell for a simulation model 
in accordance with a preferred embodiment. Figure 50 is a PInput backup cell in a simulation 
model in accordance with a preferred embodiment. Interest Rate is the parameter input for this 
model which will then be used to calculate balance and interest accumulations. A defined name 
will also have to be created for the backup of the PInput as each time interval is played. A 
requirement for this cell is that it has the same name as the original PInput, but also have the 
"JBU" extension. The example here would be c lnterest_Rate_BU." This cell will also have to 
be created in a column where no other data exists , since all of the backups are written below this 
cell. In the ICA, define a task that will be assigned to the simulation. For example, a TaskID of 
123 is generated by the ICA. For this example, we will assume that we want to give feedback on 
the interest rate selected by the student. In the ICA, define a Target for the parameter input. 

A PInput table record in accordance with a preferred embodiment is presented below. 



PInputID: 


12345 


TaskID: 


123 


ModellD: 


1 


InputName: 


Interest Rate input 


InputDesc: 


Interest Rate input into interest 
calculation model 


ReferenceName: 


Interest_Rate 


SimReferenceName 


Param_Interest_Rate 


TutorAware: 


True 


SourceltemID 


1201 


TargetID: 


4001 


Row: 


6 


Column: 


3 


SheetName: 


Sheetl 
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Once the configuration is completed, the designer can also use the ICA Utilities to test the 
simulation. The Row, Column and SheetName values are automatically populated when the 
designer runs the parameters in the System Dynamics Workbench in the ICA Utilities. The 
reason for obtaining the cell coordinates is that the processing of cell data is significantly faster 
5 with cell positions than simply using the defined name. The system dynamics engine decodes 
the defined name (Reference Name) that the designer entered, and populates the table 
accordingly. This is an important step because there have been occasions when a designer would 
change the layout of a spreadsheet, i.e., move a defined name location, and then forget to 
perform this step. As such, bizarre data was being passed to the tutor; whatever data happened to 
10 reside in the old row and column. Cells in the spreadsheet that are the output from a system 
dynamics models can be represented by parameter output objects (POutputs). Every POutput 
has an interface as detailed below. 





Field Name 


Data Type 


Description 




PoutputE) 


Long 


Primary Key for the table 


in £ 
U i 


TaskID 


Long 


TaskID of the task associated with the parameter 
output 


m 


ModellD 


Long 


ID of the model associated with the parameter output 




OutputName 


String*50 


Name of the parameter output (informational 


i; ; 






purposes) 


!! :»s 


OutputDesc 


String*255 


Description (informational purposes) 


« ; 


ReferenceName 


String*50 


Name of the spreadsheet cell associated with the j 
parameter output 




SimReferenceName 


String*50 


Name of the associated parameter in the system 
dynamics model 




TutorAware 


Boolean 


Whether the ICA should be notified of any changes 
to the parameter output 




SourceltemID 


Long 


SourceltemID of the parameter output 




Target© 


Long 


TargetID of the parameter output 




Row 


Long 


Spreadsheet row number of the parameter output 
(used for speed optimization) 




Column 


Long 


Spreadsheet column number of the parameter output 
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(used for speed optimization) 


SheetName 


String*50 


Sheet name were the parameter output is located 
(used for speed optimization) 



All of this information is stored for every output in the Output table of the simulation database 
(ICASim.mdb). Each POutput object conprises a spreadsheet cell that is an output from the 
system dynamics model. This is the information that shows the student the results of their 
5 choices and is the main reason for using system dynamics. The POutput can be made 

TutorAware, which will notify the ICA of any changes to the cell when all the POutputs are 
processed otherwise the ICA will be unaware of any changes. When the ICA is notified of a 
change, two messages are in fact sent to the ICA: 

1. An ICANotifyDestroy message with the parameter output information i.e., SourceltemID, 
10 TargetID and null as Attribute. This message is to advise the ICA to remove this information 

from its memory. 

2. An ICANotifyCreate message with the parameter output information i.e., SourceltemID, 
fn TargetID, Attribute (cell numeric value) . This message is to advise the ICA to add this 

% information to its memory. 

U1 15 As opposed to PInputs which notify the ICA on every change, POutputs are processed in batch 
y ;; just before asking the ICA for feedback . 



POutputs use is illuminated below by an example that builds on the previous interest calculation 
J*f example. Here, we want to notify the ICA of the balance as it results from changes in the 
20 interest rate. Figure 51 is a display illustrating a POutput cell in accordance with a preferred 
embodiment. The steps required to configure the POutput are presented below. 



1 . Define a name for cell G4 in Excel. Here we have defined "Balance." 

2. Define the name of the backup cell as "Balance_BU" in a blank column. 

25 3. Let's use the same TaskID as before since the Balance parameter is part of the same 
simulation as the Interest Rate parameter. Ex: TaskID is 123. 

4. In the ICA, define a Target for the parameter output. Ex: a TargetID of 4005 is generated by 
the ICA. 
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5. In the ICA 5 define a Sourceltem for the parameter output. Ex: a SourceltemlD of 1215 
generated by the ICA. 

6. Associate the parameter output to a system dynamics model (refer to Model object 
discussion). 

7. Add the information in the POutput table of the simulation engine database. This 
configuration can also be done within the ICA Utilities. 



The record in the POutput table would look something like this: 



OutputID: 


12347 


TaskED: 


123 


ModellD: 


1234 


OutputName: 


Balance Value 


OutputDesc: 


Value of Balance after model has 
been run 


ReferenceName: 


Balance 


S imReferenceName 


Param_Balance 


TutorAware: 


True 


SourceltemlD 


1215 


TargetID: 


4005 


Row: 


4 


Column: 


7 


SheetName: 


Sheetl 
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The following information provides details describing the interaction components in accordance 
with a preferred embodiment. 



Title 


Description 


Procedural tasks (w/drag 
drop) 


Tasks which require the construction of some kind of report 
with evidence dragged and dropped to justify conclusions 


Procedural tasks (w/o drag 
drop) 


New task designs that are procedural in nature, have very 
little branching, and always have a correct answer. 


Ding Dong task 


Tasks that interrupt the student while working on something 
else. This template includes interviewing to determine the 
problem, and a simple checkbox form to decide how to 
respond to the situation. 


Analyze and Decide (ANDIE) 
task 


Most commonly used for static root cause analysis, or 
identification tasks. Developed on SBPC as a result of 3 
projects of experience redesigning for the same skill. 


Evaluate Options (ADVISE) 


Used for tasks that require learner to evaluate how different 
options meet stated goals or requirements. Developed at 
SBPC after 4 projects experience redesigning for the same 
skill. Does not allow drag drop as evidence. 


Run a company task 


Time based simulation where student "chooses own 
adventure". Each period the student selects from a pre- 
determined list of actions to take. Developed on SBPC as a 
simplified version of the BDM manage task. 


Use a model task 


When user needs to interact with a quantitative model to 
perform what if analysis. May be used for dynamic root 
cause analysis - running tests on a part to analyze stress 
points. 


ICA Dynamic Meeting Task 


Developed on BDM to mimic interaction styles from Coach 
and ILS EPA. Supports dynamic-rule based branching - will 
scale to support interactions like EnCORE defense meetings 
and YES. 


Manage Task 


Time based simulation where student manages resources. 
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Human Resources Management, managing a budget, manage 
an FX portfolio. 


QVID Static Meeting Task 

- 


Developed on Sim2 to support agenda-driven meetings 
where user is presented with up to 5 levels of follow-up 
questions to pursue a line of questioning. As they ask each 
question, it's follow-ups appear. 


Flow Chart Task 


Will support most VISIO diagrams. Developed on Sim2 to 
support simple flow chart decision models. 


QVID Gather Data 
Component 


Static flat list of questions to ask when interviewing 
someone. Not used when interviewing skills are being 
taught (use QVID Static meeting task). Supports 
hierarchical questions and timed transcripts. 


Journalize Task 


Created to support simple journal entry tasks with up to 2 
accounts per debit or credit. 


New Complex Task 


A new task that requires a simulation component 
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Systems Dynamic Engine 

The system dynamics engine is the interface between the simulation model, the system dynamics 
model, the simulation database and the Intelligent Coaching Agent. The system dynamics 
5 engine is of interest to the designer so that she can understand the mechanics of it. Once the 
designer has constructed the simulation model (Excel Spreadsheet), built the system dynamics 
model (PowerSim) and configured all of the parameter inputs and parameter outputs, a test can 
be performed using the workbench included in the ICA Utilities (refer to ICA Utilities 
documentation). The developers, in turn, need to implement the calls to the system dynamics 
10 engine in the GBS application that is being built. The following list identifies the files that need 
to be included in the Visual Basic project to use the system dynamics engine. 



5 


WSysDynEng.cls 


System dynamics Engine class 


C3 


wSysDynEng.bas 


System dynamics Engine module (this module was 


%» : 




introduced only for speed purposes because all the code 






should theoretically be encapsulated in the class) 


if I 'T: 


wConst.bas 


Intelligent Coaching Agent constant declaration 


yi 


wDeclare.bas 


Intelligent Coaching Agent DLL interface 




wlca.cls 


Intelligent Coaching Agent class 


s - 


wlca.bas 


Intelligent Coaching Agent module (this module was 






introduced only for speed purposes because all of the code 


§5 if? 




should theoretically be encapsulated in the class) 



To utilize the system dynamics engine fully, the developer must place code in different strategic 
1 5 areas or stages of the application. 

1) Initial stage - the loading of the form containing the simulation front-end. This is when the 
simulation model and system dynamic engine are initialized. 

2) Modification stage - Takes place when the user makes changes to the front-end that impacts 
the simulation model PInputs). This is when the ICA is notified of what's happening. 

20 3) Run stage - The system dynamics model is run and parameter outputs are received. 

4) Feedback stage - The user requests feedback on the work that they have performed. This is 
when the simulation notifies the ICA of all output changes. 
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5) Final stage - The simulation front-end unloads. This is when the simulation model is saved. 

These stages will be explained by including the Visual Basic code involved as well as a short 
description of that code. 

5 

Initial Stage Code In Accordance With A Preferred Embodiment 
1. Creating the ICA & the simulation engine objects 

Code: 

Set moSysDynEngine = New classSysDynEngine 
1 0 Set moICA = New classICA 

Description: The first step in using the system dynamics engine is to create an instance of the 
classSysDynEngine class and also an instance of the classICA class. Note that the engine and 
ICA should be module level object "mo" variables. 

015 2. Loading the simulation 

*l Code: 

W IRet = moSysDynEngine.OpenSimulation(FILE_SIM ? Me.bookSim, True) 
jy«j IRet = moSysDynEngine.LoadSysDyn(mlICATaskID, DB SIMULATION, 1) 
? . IRet - moSysDynEngine.LoadModel(MODELJS[AME 5 mbTaskS 

§4 20 

7^ Description: After the object creation, the OpenSimulation, LoadSimulation and LoadModel 
p methods of the system dynamics engine object must be called. The OpenSimulation method 

reads the specified Excel 5.0 spreadsheet file (FILE_SIM) into a spreadsheet control (bookSim). 

The LoadSysDyn method opens the simulation database (DB_SIMULATION) and loads into 
25 memory a list of parameter inputs and a list of parameter outputs. The LoadModel method opens 

a system dynamics model (MODEL NAME). Every method of the system dynamics engine 

will return 0 if it completes successfully otherwise an appropriate error number is returned. 

3. Initializing and loading the Intelligent Coaching Agent 

30 Code: 

IRet = moICA.Initialize(App.Path & "V* & App.EXEName & ".ini", App.Path & 
DIRJDATABASE, App.Path & DIRJCADOC, App.Path & "\") 
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IRet = moICA.LoadTask(mlICATaskID, ICAStudentStartNew) 

Description: The system dynamics engine only works in conjunction with the ICA. The 
Initialize method of the ICA object reads the application .ini file and sets the Tutor32.dll 
appropriately. The LoadTask method tells the ICA (Tutor32.dll) to load the .tut document 
associated to a specific task in memory. From that point on, the ICA can receive notifications. 
Note: The .tut document contains all the element and feedback structure of a task. Ex: 
SourcePages, Sourceltems, TargetPages, Targets, etc... 



4. Restoring the simulation 

Code: 

IRet = moSysDynEngine.RunPInputs(MODEL_NAME, True) 

J* IRet = moSysDynEngine.RunPOutputs(MODELJs[AME, True) 

ii'j. 

Q 1 5 IRet = moSysDynEngine.PassPInputsAll 

jjj Call moICA.Submit(O) 

W Call moICA.SetDirtyFlag(0, False) 

IJ! 

f Description: Restoring the simulation involves many things: 

kk 20 • clearing all of the parameter inputs and outputs when the user is starting over 



• loading the interface with data from the simulation model 

• invoking the PassPInputsAll method of the system dynamics engine object in order to bring 
the ICA to its original state 

• invoking the RunPInputs and RunPOutputs methods of the system dynamics engine object in 
25 order to bring the system dynamics model to it's original state 

• calling the Submit method of the ICA object to trigger the ICA to play all of the rules 

• calling the SetDirtyFlag of the ICA object to reset the user's session. 

Running parameters involves going through the list of TutorAware PInputs and POutputs and 
30 notifying the ICA of the SourceltemID, TargetID and Attribute value of every one. 



Modification Stage 
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h Reading parameter inputs & outputs 

Code: 

Dim sDataArray(2) as string 

Dim vAttribute as variant 

Dim ISourceltemID as long, lTargetED as long 

IRet = moSysDynEngine.ReadReference("Input_Name", vAttribute, ISourceltemID, ITargetID, 
sDataArray) 

Description: The ReadReference method of the system dynamics object will return the attribute 
value of the parameter input or output referenced by name and optionally retrieve the 
SourceltemID, TargetID and related data. In the current example, the attribute value, the 
SourceltemED, the TargetID and 3 data cells will be retrieved for the parameter input named 
InputName. 

2. Modifying parameter inputs 

Code: 

Dim vAttribute as variant 
Dim ISourceltemID as long 
Dim sDataArray(2) as string 
vAttribute=9999 
sDataArray(0)="Data Cell #1" 
sDataArray(l)="Data Cell #2" 
sDataArray(2KData Cell #3" 

IRet = moSysDynEngine.WriteReference("Input__Name", vAttribute, , sDataArray) 

Description: To modify a parameter input, call the WriteReference method of the system 
dynamics object and pass the PInput reference name, the new attribute value and optionally a 
data array (an additional information to store in the simulation model). The system dynamics 
engine notifies the ICA of the change. 
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Run Stage 

1. Playing the System Dynamics Model 

Code: 

IRet - moSysDynEngine.PlayModel(SYSDYN_PLAYSTEP) 
IblCurrentTime. Caption = moSysDynEngine.CiirrentTime 
lblLastTime. Caption = moSysDynEngine.LastTime 

Description: Playing the system dynamics model is also handled by the system dynamics 
engine. There are three ways that the models can be played, all at once, one step at a time 
(shown above) or until a specific point in time. These are the parameters that are passed into the 
PlayModel method. Playing of the model generates the parameter output values and passes the 
Tutor Aware POutputs to the ICAT. The engine also keeps track of time and these values can be 
read using the CurrentTime and LastTime properties. 

2. Jumping Back in a System Dynamics Model 

Code: 

IRet = moICA.LoadTask(mlICATaskID, ICAStudentStartNew) 
IRet = moSysDynEngine.JumpBack(TIME_TO_JUMP_TO) 

Description: Because the system dynamics engine writes backup copies of the parameters 
passed to and from it, it can start over and resubmit these values back to the system dynamics 
model until a given period of time. To do this, the code would need to restart the ICA and then 
call the system dynamics engine to jump back to a given time (TIME_TO_JUMP_TO). 

Feedback stage 

1. Triggering the ICA Rule engine 

Code: 

lRet= moICA.Submit(lCoachID) 

Description: Once the simulation has been processed, the Submit method of the ICA object must 
be called to trigger all the rules and deliver the feedback. This feedback will be written by the 
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Tutor32.dll to two RTF formatted files. One file for previous feedback and one file for the 
current feedback. 

2. Displaying ICA feedback 

5 Code: 

Set oViewer = New CFeedbackViewer 

oViewer.CoachID = vICoachID 

Call oViewer.DisplayFeedBack(moApp) 

10 Description: The only thing required to display feedback information is to have an RTF control 
on a form and read-in the feedback files produced by the Submit method of the ICA object. 

Final stage 

§4 1. Saving the simulation model 

j| Code: 

O 1 5 IRet = moSysDynEngine.SaveSimulation(FILE m SIMULATION) 

Description: The SaveSimulation method of the system dynamics engine will save the specified 
, Excel spreadsheet to disk. 

J*. 

Q 20 Source Items and Targets relate to specific on-line objects. When these objects are selected in an 
ti activity, an associated Source Item and Target are 'mapped' into an ICA, which then looks at all 
P h of the configured rules and displays an appropriate feedback (known in the ICA as a Coach 
Item). For example, if an activity required users to drag an account name (Source Item) to a 
Journal Entry (Target), the ICA would be notified of this association and feedback would be 
25 delivered based on a set of predefined rules. 

Feedback (Coach Items) can be displayed in two ways, as a parent or as a child. Parent feedback 
can be Stand Alone text where it is the only piece of feedback delivered, or it can be used as a 
header which will support many 'children' pieces of feedback. An example of a Parent header 
30 would be feedback that stated "Look at your Journal Entries, here is what I see. . Below this 
would be multiple line items that relate to specific feedback given to the student about a Journal 
Entry. 
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This structure will be used for the on-line meetings as well. Instead of the association of Source 
Items and Targets occurring when an item is dragged, it occurs when a question is selected by 
the student. Rules will be configured based on these mappings to fire specific feedback. The 
Parent header, instead of being text, will include video information such as the video to be 
played. The children feedback includes all associated follow-up questions. 

ICA Configuration in Accordance with a Preferred Embodiment 

Figure 52 is an overview diagram of the logic utilized for initial configuration in accordance with 
a preferred embodiment. Since the structure of the feedback is the same as other on-line 
activities, the ICA can also be configured in the same manner. For ease of creation and 
maintenance of ICA feedback, it is recommended that the feedback is constructed so that only 
one rule fires at any point in time. Note that the organization of the example is one of many 
ways to structure the feedback. 

Step 1: Create a map of questions and follow-up questions 

Before designers start configuring the ICA, they should draw a map of the questions, videos and 
follow-up questions that they wish to use in the on-line meeting. This will give them a good 
understanding of the interactions as they configure the ICA. 

Step 2: Create a coach 

All feedback is given by a coach. Create a specific coach for the on-line meeting. 
Step 3: Create the Source Items and Targets 

Figure 53 is a display of the source item and target configuration in accordance with a preferred 
embodiment. Every question will have one Source Item (1) and Target (2) associated with it. 
These will be used by the ICA to show videos and follow-up questions. For organizational 
purposes and ease of reading, it is recommended that each Source Page ("0 Intro") contain all of 
the follow up questions ("Intro Ql", "Intro Q2" "Intro Q3"). Targets can be created one per 
Source Item (shown here) or one per many Source Items. This is not very important, so long as 
there are distinct Source Item and Target associations. Once the Source Items and Targets have 
been created, associate them into SourceltemTargets (3) and give them a relevance of one. 
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These are the unique identifiers which the ICA will use to fire rules and to provide feedback to 
the student. 

Step 4: Create the Parent Header (Video Information) 

Figure 54 is a display of video information in accordance with a preferred embodiment. 
5 Feedback (Coach Items) are organized into Target Groups (1). In Figure 54, each on-line 
question has one Target Group for ease of maintenance. Each TargetGroup must have at least 
one related Target (4). These are the SourceltemTarget mappings that were made at the end of 
Step 3. Next, Rules (2) are created to fire when the SourceltemTarget is mapped (a question is 
clicked). Coach Items (3) are associated to a rule and represent the feedback which will be 
1 0 shown if the rule is fired. 

Figure 55 illustrates a display depicting configured rules in accordance with a preferred 
embodiment. Rules are configured to fire when specific Source Items and Targets are mapped 
Jj; (when a user clicks on a question). For this reason, Aggregate Rules are configured that only 
0 1 5 look to see if this mapping has occurred. To have the rules query these mappings, the Target 
|"j Group field (1) is equated to the Target that was mapped to this Target Group. For the rule to 
p fire, special criteria have to be satisfied. The Source Item and Target are assigned a relevance of 
? one so they will be recognized as a correct mapping (or UCP). Therefore, this rule fires if there 
is a minimum of one correct mapping, or UCP (2). Using this format, only one rule will fire at 
p 20 any point in time because only one question will be selected at any point in time. 

ij ;-*s 

N s Figure 56 illustrates feedback for configured rules in accordance with a preferred embodiment. 
Each rule has associated feedback (Coach Items) that depict when a rule is fired. To configure 
this feedback as a header, this Coach Item must be configured as a parent (1). Since this Coach 
25 Item is a header and will show other children feedback, the number of children displayed must 
also be set (2). This will be the number of follow up questions for the selected question. The 
feedback window is where the header text is configured relating the video information that will 
appear as a result of a question being selected (the Sourceltem and Target mapping). 

30 To separate the video information, the feedback text includes specific tags. To state the filename 
for the video played, the name must be inside the <F> and </F> tags. The start time for the 
video to play uses the <I> and </I> tags and the stop time uses the <0> and </0> tags. 
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Transcripts can also be used to show on screen or for the purposes of testing feedback without 
video. The tags for transcripts are <T> and </T>. 

Step 5: Create the Children (Follow- Up Questions) 

5 Figure 57 illustrates a display with follow-up configuration questions in accordance with a 

preferred embodiment. To configure the follow-up questions, each follow-up question is defined 
as a child in the same target group as the header. Remember that the header here was configured 
to have three children and there are also three follow-up question children configured. Each 
child also has one Rule and Coach Item associated with it. 

10 

Figure 58 illustrates configuration of aggregate rules in accordance with a preferred embodiment. 

The Aggregate Rules for the children are configured exactly the same as the parent header. 
},£ Notice that the Target Group Target is the same Target as the parent. The Rule is also firing 
I J when this Target Group has a positive mapping (UCP of one). These rules are created in the 
O 1 5 same way so that the parents and children all fire at the same time. 

1^ Figure 59 illustrates a set of coach items in accordance with a preferred embodiment. 

s The Coach Items for the children represent the follow-up questions. The coach items must be 

Li. 

[ J" configured as children (1) so that they are properly associated with their respective parent. The 
0 20 feedback text (2) is the caption for the follow-up question. 

•hi i; 
f 1 

H Configuring Utilities 

Once the ICA configuration is complete, there is one last step to the process. In order for the 
selection of a question to drive other questions and videos, each question must relate to one 

25 Source Item and one Target. This way, when any question is selected, the ICA is notified and 
the next video and group of follow-up questions can be displayed. In the ICA Utilities Suite, in 
accordance with a preferred embodiment, there is an ICAMeeting Configuration tool which 
maps the individual Coach Items (Questions) to a Source Item and a Target. The Coach Item ID 
to be entered is the question that is selected by the user and the Source Item and Targets entered 

30 relate to the Target Group Targets that drive the video and follow up questions. 
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Figure 60 is an ICA Meeting Configuration tool display in accordance with a preferred 
embodiment. To add a new association, click on the Add New button on the toolbar (1). Here, 
designers can type the Coach Item, Source Item or Target Ids to associate. Another utility, the 
Object Viewer, can be used, which will display all of the relevant Coach Items, Source Items and 
5 Targets. These can then be dragged to the respective fields. All of the associations can be 
viewed from the grid depicted on the left side of the utility (2) in Figure 60. 



Once the ICAMeeting has been configured, it can be implemented or tested using Visual Basic. 
This would represent the on-line questions and videos that are driven by the ICA feedback. 
10 Below are the steps required to perform this action. In order to use the ICAMeeting in Visual 
Basic, the xIC AMeeting.cls and xIC AMeeting.bas files are required. Note that the Visual Basic 
components required for the ICA (wICA.cls, wICA.bas, wConst.bas, wDeclare.bas) are also 
y s required for the ICAMeeting class to work. 



Using the ICAMeeting in Visual Basic 



a 15 



Step 1: Create the controls needed for the ICA meeting 

• Create a command button as a control array for the questions 

• Create a picturebox for the video to play 



Create a RichTextbox control to receive the ICA feedback 



Create a textbox for the transcripts of the video to appear 



Step 2: Configure the ICA Meeting 




• Initialize class 



Set moICAMeeting = New classICAMeeting 



25 



• Configure parameters: 

Set coachID to the ID created in the ICA for the coach 
moICAMeeting. CoachID = 4 



State if videos should show the control box to play and stop videos 
moICAMeeting. ShowClip = True 
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Initialize class and pass in Question Button, Rich text control, Video picturebox and 
Transcript text field 

Call moICAMeetingJnitialize(cmdQuestion(), rtxtHeader, picVideo, txtTranscript) 

• Set Question Click Event and pass in index of control array button clicked 
Call rnoICAMeeting. OnQuestion Click(Index) 

• Set Restart method (if desired) and pass in the ED of the task as configured in 
the ICA 

Call moICAMeeting.RestartMeeting(mlICA TaskID) 

Debugging 

When debugging the on-line meeting, check that the following requirements exist. If any of 
these criteria are not met, the meeting will not work properly. 



Target Groups 

Target Groups 



Must have a Target that relates to a Source Item and Target Mapping ( ==^) 
Should contain the header and a few children 



Parent Coach Items (Video Information) 

Rules 

• Must use the coach defined for the activity 
^ Aggregate Rule 

• Must have the Target that was assigned to the Target Group f SP) 

• Must have a UCP minimum of 1 

Q Coach Items 

• Must be designated as a parent 

• Must contain at least one child 
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• Feedback must be configured using the <F>,<I>,<0> and <T> tags 



Children Coach Items (Follow Up Questions) 

^ Rules 

• Must use the coach defined for the activity 
Aggregate Rule 

• Must have the Target that was assigned to the Target Group (9) 

• Must have a UCP minimum of 1 

^? Coach Items 

• Must be designated as a child 

• Feedback must include text for a follow up question 

Intelligent Coaching Agent (ICA) Utilities 

The Intelligent Coaching Agent Tool (also known as the tutor) was used to create remediation 
for the activities within the course and the architecture passed values to the tutor. One drawback 
was that the architecture did all of the processing and, therefore, all of the simulation. This was 
not the most data driven or most efficient way of creating business simulation because any 
changes to activities had to made within code. 

The ICA Utilities incorporate business simulation into a multimedia application. What this 
means is that there is now a middle layer between the application and the ICAT. These utilities, 
along with the simulation engine (described later), allow the architecture to be a front end to the 
simulation. Now, any changes to a simulation model do not need to be incorporated into code. 
The ICA Utilities and simulation engine work with simulation models created in Microsoft 
Excel. After the model is created, the designer uses the Defined Name function in Excel to flag 
specific cells that are to be used by the application and the ICA Utilities in accordance with a 
preferred embodiment. Figure 62 illustrates an ICA utility in accordance with a preferred 
embodiment. The ICA Utilities consist of six utilities that work with the Intelligent Coaching 
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Agent Tool (ICAT) to incorporate business simulation with the multimedia application. Below 
is a description of each utility, which will be discussed in detail following this introduction. 

• The Object Editor is used for the configuration of objects that translate simulation variables 
into values passed to the ICAT. This is really where the "middle layer" of the simulation is 
configured. 

• The Simulation Workbench allows designers to test their spreadsheets once they have 
configured the simulation. Therefore, the testing of feedback can start well before testing, or 
even before any code is written at all! 

• The Object Viewer is a tool that shows the designer the ICAT objects. This can be used for 
viewing purposes without using the ICAT. 

• The Log Viewer shows all of the logs associated with the ICAT. This is helpful in 
debugging feedback received in the Simulation Workbench. 

• The ICA Doc Maker also designers to create TutorDoc files. These are the final outputs of 
the ICAT, which are used by the application to remediate. 

• The Feedback Reviewer utility allows designers to resubmit previously submitted work to 
the ICAT. 

Navigation: 

Figure 62 illustrates a configuration utility display in accordance with a preferred embodiment. 
When first entering the Utilities, a user must select their user name (1) and the Task they wish to 
work on (2). User names can be added in the Object Editor (discussed later). Some of the 
utilities require user names to be selected and will not open without them. To open any of the 
ICA Utilities, users select the utility from a toolbar (3), or use the Utilities menu item which is 
accessible from any screen. Depending on which utility is open, other menu options become 
available. Because the ICA Utilities have six different utilities that can be opened at one time, 
these windows can be arranged for ease in viewing. The Window menu item, which is accessible 
from any screen allows multiple windows to be cascaded, tiled horizontally or tiled vertically. 

At the bottom of the ICA Utilities, there is a status bar that relays information to the user. When 
the mouse is moved over key items in the utilities, such as the toolbar icons or utility buttons a 
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description of what these objects do appears on this status bar. The status bar also displays 
information when processing is occurring as to what the utility is currently doing. 



i£_rfThe Object Editor: 

The Object Editor is used to translate application information into values for the ICAT, which 
5 can then be remediated upon. 

Figure 63 illustrates an object editor toolbar in accordance with a preferred embodiment. The 
Object Editor uses this toolbar on the side of each configuration display. To add a new object, 
the Add New button is selected. To edit an existing object, highlight that object and click on the 
10 Edit button. To delete an existing object, highlight the object and click the Delete button. When 
an object is being added or edited, the OK and Cancel buttons become enabled. To save 
changes, the OK button is selected and to cancel any changes, the Cancel button is selected. 
Objects are scrolled by using the arrow buttons on the bottom of the toolbar. There is also a 
counter that displays the current record and how many total records are currently defined. 



fill 15 

jj^ Figure 64 illustrates the seven areas that can be configured for a simulation in accordance with a 
!yl preferred embodiment. 



fiSSl Paths are used to pass select information to the ICAT. If specific data needs to be passed 
G to one coach (the ICAT allows for multiple team members to give feedback), while other data 
q 20 needs to be passed to a different coach, two Paths can be used to allow all of the data to be stored 
in one simulation model. 

Figure 64 illustrates a display that defines inputs in accordance with a preferred embodiment. 



Inputs are configured for the contributions in a simulation model. Using a model of a + b 
25 = c, "a" and "b" would be inputs. To configure an input, a name and description are given for 
informational purposes. A reference must also be provided. This is the Defined Name on the 
simulation spreadsheet where the input value resides. This reference is used by the Simulation 
Engine to locate the sheet and cell location of the input. Note that the Simulation Workbench 
can configure and view these defined names. These defined names can be typed in or dragged 
30 from the Simulation Workbench utility. A path must also be selected for an input. This is where 
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a designer can be selective as to what information to pass to a coach in the ICAT. Because of 
this, at least one path must be created before an input can be properly configured. 

Inputs can also be used by the application, but not passed to the ICAT. To pass objects to the 
5 ICAT, a designer must specify the awareness of the Input tutor of the input. If the Input is to be 
passed to the ICAT, then a TargetID must be given to this input. Here is where the Object 
Viewer can be used. Target Ids can be typed in or dragged from the Object Viewer. 
SourceltemlDs can also be configured here. This should only be done if the Input has only one 
choice (such as a textbox). Multiple choices, such as a combobox or option buttons, allow for 
10 multiple SourceltemlDs and therefore, in those cases, this field should be left blank. Outputs are 
configured for outputs in the simulation model. Using the same example as above (a + b = c), 
"c" would be the output. Outputs are derived from inputs into a model. Outputs are configured 
exactly the same as inputs. 

g 3 1 5 Figure 66 illustrates a list editor in accordance with a preferred embodiment. 
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finraLists are used to pass multiple objects to the ICAT. This is useful when there are many 
items to be passed to the tutor that are not static. For example, a drag-drop area where any 
number of items can be dragged over can be configured as a List. Dragging points over would 
add to the list, and dragging points off would delete from the list (and the ICAT). To configure a 
jj 20 list, the designer must use multiple columns in the simulation model and no other information 
can be used in these columns. This is because when a list deletes an item, it shifts up all other 
cells below it. The defined name for the list is the first row where the first value resides. Lists 
also use the Name, Description, Reference and Path fields. Note that lists can also be Tutor 
Aware and must be assigned to a target. The one field used by a list that is different than an 
25 input or an output is the Total Columns field. This process defines how many columns are used 
by the list, including the defined name of the list. 



* 



'>*"*"•:' Students are configured for the ICA Utilities. Figure 67A illustrates a define student 
display in accordance with a preferred embodiment. Students are the designers of the simulation 
30 models. A student must be selected before the other utilities can be used. Therefore, adding 
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students should be the first task when using the utilities. Student name and description are used 
for informational purposes. The student ID is an identifier for the user and can be any number. 



II 



ControlSourceltems are SourceltemID values that can be stored to be used by the 
5 application. Figure 67B illustrates a ControlSourceltem display in accordance with a preferred 
embodiment. SourceltemDDs are Ids that the application must pass to the simulation engine, 
which then passes them to the ICAT. A SourceltemID relates to one data object that is being 
remediated on, such as a text field of account number. Using ControlSourceltems, the 
SourceltemlDs no longer have to stay hard-coded in the application and can change without any 
10 effects on code. ControlSourceltems can be configured for a combobox of all twelve months. 
Therefore, the first item in the combobox can be January, the second can be February and so on. 
When the user selects a month, the application uses the index of the combobox to find the 
ControlSourceltem and pass that to the simulation engine. 



jj 15 ControlSourceltems are configured using a name and description for informational purposes. 
Module Name refers to the task that these items reside in. These can be used for logical 
groupings of ControlSourceltems. The Item number is an index used to distinguish between 
ControlSourceltems (for example, the combobox listindex property). The SourceltemID for that 
ControlSourceltem is also needed and can be dragged from the object editor. 



v ~" ControlTargets are like ControlSourceltemlDs, but instead of storing SourceltemlDs they 
store TargetlDs. If a Sourceltem is something that is dragged from , then a Target is something 
that is dragged to. 



The Simulation Workbench: 

25 The Simulation Workbench is used by designers to test the feedback created in the ICAT. It can 
also be used to configure simulation models. Simulation models can be imported by using the 
File menu path and then Open. Figure 68 illustrates a simulation workbench in accordance with 
a preferred embodiment. Once a simulation model has been loaded, the designer can enter 
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values into their inputs and outputs and test the feedback. Notice here that the example of 1 + 2 
= 3 is used with 1 and 2 being configured as inputs and 3 an output. 

When a cell with a defined name is highlighted (here it is call B6), the Defined Name appears in 
5 the Active Cell Name field (1). This defined name can be dragged from this field to the Object 
Editor for configuration purposes. To run a simulation, the utilities need to be started. Click on 
the Start Over button (2). At this time, all of the Paths associated with that task will populate 
the Path list (3). Also, any coaches configured in the ICAT will populate as buttons on the 
bottom of the toolbar (5) with an associated path. To run a simulation, select the simulation and 
10 click on the Run Simulation button (4). By running the simulation, all of the defined inputs, 

outputs and lists are passed to the simulation engine which then passes the Tutor Aware objects to 
the ICAT. The remediation can now be viewed by clicking on any of the coaches on the bottom 
of the toolbar (5). By utilizing a Simulation Workbench, a designer can change inputs and 
outputs to simulate what the application will do and see their feedback, without any code being 



i;f _.. The Object Viewer: 

in The Object Viewer is a snapshot of the ICAT configuration. Although ICAT objects, such as 
1^ Targets and Sourceltems cannot be configured in the object viewer, the utility is good for 

viewing the objects as feedback and is used in the Simulation Workbench. Figure 69 illustrates 
jyi 20 an object viewer in accordance with a preferred embodiment. As shown in Figure 69, the object 
?? viewer lists the SourcePages, Target Pages and Target Groups for a selected task. By examining 
further details associated with these objects, designers can obtain specific information, such as 
SourceltemED numbers and the values that are mapped as correct answers. SourceltemlDs and 
TargetDDs can be dragged from the graphical hierarchy on the left to the Object Editor to 
25 configure Inputs, Outputs, Lists, ControlSourceltems and ControlTargets. 

Figure 70 illustrates an Object Viewer Configuration in an Utilities menu in accordance with a 
preferred embodiment. The object viewer configuration display facilitates interactive user 
selection of ICAT objects to view in the Object Viewer. These selections are saved for the 
30 designer as their preferences so that the next time the user utilizes a utility, the preferences are 
utilized as the user's predefined settings. 




written yet. 
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ll# The Log Viewer: 

The Log Viewer utility is used to view the logs created by the ICAT. These are very helpful in 
debugging feedback. Figure 71 illustrates a log viewer in accordance with a preferred 
embodiment. 

5 

• The Debug Log shows every object passed to the ICAT. If an account was dragged to a 
journal page, then the SourceltemID (account) and target (Journal page) are mapped with 
the attribute (amount journalized). If an object is deleted, it is also noted here. 

• The General Log shows general ICAT data such as the Target Groups, Rules and 
1 0 feedback received. 

The Load Log shows the ICAT objects used when the ICAT was loaded. 
The Student Log groups ICAT data by Target Group and shows the number of correct, 
U incorrect or extra items in that group. This log also shows every ICAT rule as well which 

|| ones have been fired and which ones have not. 

0 15 • The Last Submission Log shows the feedback received from the last submission to ICAT. 

" '. 7, 
•'5? 5? 

fj j • The Error Log shows any errors that were incurred by the ICAT. 



■ The Doc Maker: 

L ;; The Doc maker is used to make IC A Docs, which are used by the application and the Simulation 

Workbench to process information and give remediation. Figure 72 illustrates a Doc Maker 
lifl 20 display in accordance with a preferred embodiment. To create an ICA Doc, a user selects the 
database from where the ICAT data is stored. Then, select the Document Path where the ICA 
Doc will be created to. Finally, select the desired tasks and click on the Make Docs button. 



Si J The Feedback Reviewer: 



The feedback reviewer utility is used after the configuration process is complete and other users 
25 are working with the application. The application stores all of the ICAT submissions in a student 
table, which can then be passed back to the ICAT after changes have been made. Figure 73 
illustrates a Feedback Reviewer display in accordance with a preferred embodiment. A user first 
selects a saved student profile by positioning the cursor over and clicking the Student combobox 
(1). This action invokes logic which then populates any tasks that the student performed in the 
30 Task list (2). By selecting a task, all of the submissions that the student performed populate the 
submission table (7). 
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To view a submission, click on the submission in the submission table (7). This will populate all 
of the Targets, Sourceltems and Attributes submitted at that time in the submission data table (6). 
Also, any comments added by the tester in the application will appear in the Tester Comment 

5 Field (8) as well as the feedback received for that submission (9). To resubmit this data to the 
ICAT, click on the Load Archive button (3). This action loads the Sourceltems, Targets and 
Attributes from the Submission Data (6) into the ICAT. Then, this data can be replayed one step 
at a time by clicking the Replay button (5) or all of the data for all submissions can be replayed 
by clicking on the Replay All button (4). After this data is replayed, the Current Feedback field 

10 (1 1) is populated with the feedback received. Any comments can be added to the Fixer 

Comments field (10). This utility efficiently facilitates student submissions transmission to the 
ICAT without recreating the work. ICAT rules can be configured and then the submissions can 
be replayed to test the associated changes. 



p 15 The following example is provided to step through the process for using the ICA Utilities: 

||J Objective: 

ilj The objective here is to create a task where users will journalize an invoice and receive feedback 

fll 

m on their work. 



After planning the task, the designer should add all relevant information to the ICAT such as the 
Sourceltems (Accounts), Targets (Invoices), Attributes (Amounts to Journalize) and any Rules 
they wish to create. For this example, the correct answer is created in the ICAT (Debit 



Machinery for $1,000 and credit Accounts Payable for $1,000) along with some basic rules and 
25 feedback. 

Step 2) Create the Simulation Model: 

The tables below represent the model for the example simulation. 



Example in Accordance With A Preferred Embodiment 




Step 1) Configure the ICAT: 



Accounts 



Sourceltem 



Invoice 1 



Accounts Payable 



1 



Wills Machinery 

Two pressing machines were 
purchased on account for $1,000. 



Accounts Receivable 2 
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Cash 
Machiner 

y 



3 
4 





Account 
SID 


Amount 


Debit 
Credit 




DRAMOU 
NT 




CR_AMOU 
NT 



'•K fi 



10 



f1 



15 



The three tabular displays appearing above show an invoice associated with the purchase of two 
machines on account. We also see the SourceltemlDs for the possible accounts (these were 
configured in the ICAT). In the simulation model, defined names were given for the Amount 
fields in both the Debit (DRAMOUNT) and Credit (CR_AMOUNT) fields. The SourceltemID 
field is created to the left of the attribute field and the attribute field always has the defined 
name. This is because the simulation engine finds the Defined Name and gets the attribute from 
there. Then, it looks to the left of the defined name to find the SourceltemID. 

Step 3) Configure the Inputs, Outputs and Lists 

For this example, only 2 inputs are needed and they are the debit and credit entry for the invoice. 
In the Object editor, create a path to be used to pass the inputs to the ICAT. Then, configure the 
inputs using the DR AMOUNT and CR^AMOUNT defined names and the Target defined in the 
ICAT. Figure 74 is an object editor display that illustrates the use of references in accordance 
with a preferred embodiment. The reference is used in the defined name (DR_AMOUNT), the 
Input is Tutor aware and will be mapped to TargetID 300 (created in the ICAT to distinguish the 
debit for this invoice). The credit input is created in the same way. 



Step 4) Test the Feedback in the Simulation Workbench 

20 Designers can open the Simulation Workbench and load the model that was created in Step 2. 
Then, different SourceltemlDs for the accounts and the amounts can be changed in the model. 
During this time, designers can Load and Run the Simulation to see the feedback. One example 
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entails the step of putting the Machinery SourceltemID (4) in the Debit SID field, 1,000 in the 
Debit Amount field, Accounts Payable SourceltemID (1) in the Credit SID field and 1,000 in the 
Credit Amount field to see if they get praise by the Coach. 



5 Step 5) View and debug errors 

After submitting multiple times to the ICAT, a designer can view what was passed to the tutor by 
viewing the logs in the log viewer. If there was an error, such as the correct answers being put in 
but incorrect feedback showing, these logs would prove helpful in tracking down the problem. 
Designers can also look in the Object Viewer to see the actual ICAT configuration. 
10 The combination of the Log Viewer and ICAT Viewer will help the designer in testing and 
finding any problems in their feedback. 



m 



m 



Step 6) Making changes are fixing errors 

Once the problems have been tracked down (Step 5), a designer can make the appropriate 



Q 1 5 changes in the ICAT. From the ICA Doc Maker utility, a new ICA Doc can be made and then 
5 retested all over again. 



Step 7) Building the task 

After the task has been designed and feedback created, the coder can use the ControlSourceltem 
f?& 20 object in the Object Editor utility to map the SourceltemlDs to specific accounts. Therefore, 
when a user drags an account from the chart of accounts, the application retrieves that 
SourceltemID from the ControlSourceltem list and then passes it to the Simulation Model. 

Figure 75 presents the detailed design of smart spreadsheets in accordance with a preferred 
25 embodiment. Processing commences at function block 7500 where the excel spreadsheet is 

designed to model to perform scenario planning for the application that the business simulation 
is targeted for. By way of example, a model for real estate that analyzes an own versus rent 
decision is utilized to convey features in accordance with a preferred embodiment. Function 
block 7510 illustrates the next step which entails associating drivers for specific analysis tasks 
30 that are used in the model. For example, the price of unit, down payment, tax rate, estimated 

appreciation, assessment, rent, annual rent increase, type of loan, and salary will each be utilized 
in evaluating an formulating the decision. Then, at function block 7520, a loan amortization 
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schedule is created to track the ten year equity growth, tax savings, portfolio value, net gain/loss 
schedules. 

The next step entails designing the tutor approach. First, at function block 7530, the expert 
5 metrics are identified for home buying metrics. These include the ratio of a person's salary to 
their home loan payment + assessment, new payment/rent, five year gain, % down, scenario 
assumptions regarding market and real estate appreciation. Then, at function block 7540 the 
relative weights for each metric are established and the rule structures are established that 
identify an appropriate conclusion to reach. For example, praise would entail a message saying 
10 home is a good buy, polish would entail a message that the home may be a good buy, but several 
risks should be addressed, focus parent would entail a message that the home is not a good buy 
due to the following indicators, and list the indicators suggesting that the home is not a good buy. 
Finally, a redirect message would be: are you kidding, the inputs are entirely unrealistic. 



P 15 Function block 7550 creates the focus child feedback based on a prioritization of key metrics 

such as the break even is too long, and the appreciation isn't high enough to justify the estimated 
foregone stock market appreciation, or there is not enough money down to grow equity in a short 
period of time. Finally, as function block 7560 suggests, the feedback is tested with sample 
scenario data and a user test model is created to capture user questions at interaction points of 
20 relevance, questions are attached to the tutor regression database, and the feedback is fixed and 
tested in the regression workbench. 



m 



An Example In Accordance With A Preferred Embodiment 

Complex business simulations are possible utilizing the business simulation tool set. Figure 76 
25 illustrates an example of a simulation 7600 for the training of a telephone operator and telephone 
customer service staff. 

The simulation 7600 includes a ICAT evaluator and virtual director engine and feedback 7610, a 
knowledge base 7620, multiple entities 7630, and multiple tasks 7640 for a student to learn. 
30 Other elements 7650 may also be added to the simulation. 
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The ICAT evaluator and feedback 7610 includes a method to compare student responses to 
correct responses and provide individualized feedback to the student. The functionality of the 
ICAT evaluator and feedback 7610 is more fully described above. 

5 The knowledge base 7620 includes data representing the correct methods and answers to tasks 
and a access interface for the student to utilize to search for information to assist the student's 
responses. 

A portion of the multiple entities 7630 would represent customers or other customer service staff 
10 such as supervisors, schedulers, technical support personnel and other staff members. These 
entities may be generated through the simulation or may be directed by or represent other 
students simultaneously participating in the simulation. 

A portion of the multiple tasks 7640 would include receiving customer calls, providing 
p 15 information, entering orders, forwarding customer calls to technical staff or to supervisors, and 

%t other tasks. 

fy 
11 

in Simulation construction requires several steps: 
: • Determine the goal(s) of the simulation 

pis 

H 20» Determine the core knowledge required to complete the simulation goal(s) 

• Determine the skill level of the students to be trained 
■W • Build the simulation 

• Test the simulation 

• Implement the simulation 

25 • Review and update the simulation 

A telephone operator simulation is described to illustrate an embodiment of this process. 
Administrative functions such as title, links and relationship to other simulations are not included 
but are additional capabilities of the embodiment to increase the utility of each embodiment. 



30 



Goal of the simulation 
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The goal of the simulation is to train new telephone operators in handling typical telephone and 
in-person inquiries from customers. Individual goals are built from collections of subordinate 
goals. Goals may be as simple as a single word, phrase or motion or other activity needed to 
accomplish the ultimate training goal. 

5 

Core knowledge 

The core knowledge requires several sections of information: 

• Examples of types of questions to be asked by customers 

• Preferred responses to these requests 

1 0« Examples of less than preferred responses 

• Why those responses are preferred or less than preferred 

Determine skill level of students 

In this example, the students will be limited to new hire, telephone operator trainee students. 
0 15 This simulation can also be utilized to train and evaluate experienced operators on basic skills. 
m As the knowledge base is broadened, the skill level of the trainees can include even advanced 

telephone operators, supervisors, and any other personnel that interface with telephone operators 
yi or perform similar tasks. 

** 20 Build the simulation 

Q 

y*j A domain expert works with the ICAT to build a knowledge base of the core knowledge. In this 
W example, the domain expert is an experienced telephone operator. Several different, experienced 
telephone operators may be utilized as domain experts. Each aspect of the core knowledge is 
input to the knowledge base by query by the ICAT and response by the domain expert. 

25 

The domain expert's interface may be a computer workstation 7700 as shown in Figure 77. The 
domain expert 7710 has a keyboard 7720, a display 7730, and a microphone 7740 and headset 
7750 combination which is connected to a computer processor 7760 for entering information into 
the knowledge base. Other input devices such as a mouse, video camera, scanner and others may 
30 also be utilized. The input may be in the form of keyboard entry and/or audio and video 
recordings and other types of information. 
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Figure 78 illustrates multiple domain experts 7810, 7820, 7830, 7840, collaborating to "build" a 
simulation. The multiple domain experts 7810, 7820, 7830, 7840, are connected to a common 
computer processor 7850. The multiple domain experts 7810, 7820, 7830, 7840, may be local or 
remote and connected to the computer processor 7850. The connection to the computer 
processor 7850 may be via a local network connection, remote wide area network connection, 
the internet, satellite link or any other means possible. 

The following is an example of how a new scenario or section of a simulation is built: 
Domain expert selects a menu item: EDIT SIMULATION and selects an existing simulation 
from a list, or creates a new simulation. With the simulation open, the domain expert selects a 
menu item: EDIT SCENARIO and selects an existing scenario from a list, or creates a new 
scenario. With the scenario open, the ICAT works with the domain expert to build the scenario 
through a series of prompts such as the following: 



Prompt 



Response 



Please enter a question to begin the 



scenario. 



Free text entry of a question leading 
toward completion of at least one of the 
goals of the simulation such as: "I would 
like to order a new phone line." 



Please enter a response. 



Free text entry of a response such as: 
"Hello, Thank you for calling California 
Bell Telephone, my name is 
<STUDENT_N>, how may I help you 
today?" 



What is the STATUS of this response? 



Select PREFERRED / ACCEPTABLE / 



MARGINAL / UNACCEPTABLE / 



OTHER 
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Prompt 

Response 

If OTHER is selected: Please identify the Free text entry of an additional STATUS 
STATUS of this response. type and means to rank the additional 

STATUS among the existing STATUS 

types. 

Please identify a key term or feature of the Free text entry such as "California Bell 
response. Telephone" 

Please identify another key term or feature Field entry such as <STUDENT JNf> 
of the response or NA if there are no 
additional key terms or features for this 
response. 

Repeat operation 6 until response = NA 

Please enter a video presentation of this A prerecorded video clip may be selected 
response or NA if there are no video or NA selected 

presentations for this response. 

Repeat operation 8 until response = NA 

Please enter an audio presentation of this A prerecorded audio clip may be selected 
response or N A if there are no audio or NA selected 

presentations for this response. 



Repeat operation 8 until response = NA 
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Prompt 

Please enter another response or NA if 
there are no additional responses to this 
question. 



Response 

Free text entry of a response such as: "Hi, 
Thank you for calling California Bell 
Telephone, how may I help you today?" 
or NA selected 



Repeat operations 2 through 12 until 
response = NA 



Please enter a video presentation of this 
question or NA if there are no video 
presentations for this question. 



A prerecorded video clip may be selected 
or NA selected 



Repeat operation 14 until response = NA 



Please enter a audio presentation of this 
question or NA if there are no audio 
presentations for this question. 



A prerecorded audio clip may be selected 
or NA selected 



Repeat operation 16 until response = NA 



Please enter another question or NA if 
there are no additional questions to this 
scenario. 



Free text entry of a question such as: "I 
would like to move my phone service to a 
new address" or NA selected 



Repeat operations 2 through 18 until 
response = NA 



If NA is selected, the scenario and simulation are closed. 
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Through this example iterative process the simulation may be filled with many options such as 
several different questions and responses; a variety of media, text, audio, video, and others to 
convey the questions and record the responses. This example is narrowly constrained so as to be 
merely illustrative and not comprehensive. Additional question and response methods such as 
5 audio, video, animation and virtual reality (VR) may also be included. 

Test the simulation 

To test the simulation, the domain expert logs into the simulation as a student. The simulation 
presents a basic telephone call by a customer and the domain expert would respond and review 
10 the feedback and progression of the simulation. If there are any errors the domain expert would 
then make the corrections. 

The process would repeat until the domain expert or domain experts were satisfied with the 
completeness and accurateness of the simulation. 

i is 

Implement the simulation 

! In this process, a new operator trainee-student would attempt the simulation. 

First the new trainee would be required to identify themselves to the simulation. This can 
: 20 include any number of fields of information so that the simulation can "identify" the user and the 
type of training the user has had. This information is stored in a "User Profile." The simulation 
uses the user profile to begin a record or "User Indicia file" for the user. Other types of 
information that would be automatically stored in the user indicia file would include without 
limitation, past training performance, remedial training required, user preferences and help 
25 engine usage and results. Many other types of information may be stored in this indicia file so as 
to fully record the user's use of the simulation. 

The simulation would begin with a simulated "customer" calling. The customer call maybe 
presented to the student as a text, audio, video or some other method the student maybe able to 
30 respond to. 



189 



I I ) ) 

AND1P045.P " ^ ^ # 



Figure 79 illustrates the flow of an embodiment of a Telephone Operator Training Simulation 
7900. 

The student responds 7910 to the call: Student: "Hi, may I help you". The ICAT would capture 
5 the student's response 7920. The student's response 7910 may be by text entry, multiple choice 
on the student's display screen, by audio response, video response, or any other method of 
responding. 

If the student's response is audio, as in this example, then the ICAT may time the response if 
10 necessary, then use a voice recognition module to convert the audio to text and then evaluate 

7940 the response by comparing the response to acceptable responses in the knowledge base and 
finally provide feedback 7950 to the student. 

JJj An example of a student workstation 8000 is illustrated in Figure 80. The student workstation 
p 15 8000 includes a keyboard 8010, a display 8020, and a microphone 8030 and headset 8040 
jJI combination which is connected to a computer processor 8050 for entering responses to the 



'IK- 5? 
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P* 
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m 
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simulation. Other input devices such as a mouse, video camera, scanner and others may also be 
utilized. The input may be in the form of keyboard entry and/or audio and video recordings and 
other types of information. The link 8060 to the computer processor simulation server 8050 may 
jU 20 be via a local network connection, remote wide area network connection, the internet, satellite 
fi link or any other means possible. 

Some possible examples of responses and feedback include: 

STUDENT RESPONSE STATUS FEEDBACK 

Hello, Thank you for calling Preferred Minor feedback required such as a 

California Bell Telephone, my name bright green "APPROVED" icon or 

is June, how may I help you today? a high point score appearing on 

Student's display screen 
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STUDENT RESPONSE 



STATUS 



FEEDBACK 



Hi, Thank you for calling California 
Bell Telephone, how may I help you 
today? 



Acceptable Minor feedback required such as a 
dark green "APPROVED" icon or a 
lower point score appearing on 
Student's display screen AND 
offering student the opportunity to 
query the knowledge base for the 
preferred response and to re-try the 
simulation 



Response using the word "Hi" and 
leaving out Company name or 
student name. 



Marginal Major feedback required such as a 
momentarily interrupting the 
simulation, displaying and/or 
playing an audio recording of the 
preferred response and asking if the 
student would like to re-try the 
simulation. If a point scoring 
system is used, no points would be 
awarded 



Responses shorter than 1000 
milliseconds or longer than 3000 
milliseconds 



Unacceptable Major feedback required such as a 
momentarily interrupting the 
simulation, displaying and/or 
playing an audio recording of the 
preferred response and requiring the 
student to re-try the simulation. If a 
point scoring system is used, no 
points would be awarded 



Additional STATUS levels and additional possible responses and feedback can also be added. 
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The simulation continues with an audio recording of a customer heard in the student's headset. 

Customer: "I would like to order a new phone line". 
Student: "Is this for your home?" 

ICAT captures and evaluates student response and provides feedback such as shown in the 
following possible examples: 



STUDENT RESPONSE 



STATUS 



FEEDBACK 



'Is this for your home?' 



Preferred Minor feedback required such as a 
bright green "APPROVED" icon or 
a high point score appearing on 
Student's display screen 



"Is this for your home or your 
business?" 



Acceptable Minor feedback required such as a 
dark green "APPROVED" icon or a 
lower point score appearing on 
Student's display screen AND 
offering student the opportunity to 
query the knowledge base for the 
preferred response and to re-try the 
simulation 
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STUDENT RESPONSE STATUS FEEDBACK 



"Excuse me but I need to get my 
supervisor to assist me" 



Unacceptable Major feedback required such as a 
momentarily interrupting the 
simulation, displaying and/or 
playing an audio recording of the 
preferred response and requiring the 
student to re-try the simulation. If a 
point scoring system is used, no 
points would be awarded 



Angrily shouts into the microphone: 
"You called the wrong number! 
Hang up and call 888 555-1234 to 
place telephone service orders." 
And then disconnects the customer. 



Unacceptable Major feedback required such as a 
momentarily interrupting the 
simulation, displaying and/or 
playing an audio recording of the 
preferred response, notifying the 
course director and requiring the 
student to re-try the simulation. If a 
point scoring system is used, no 
points would be awarded 



Feedback, similar to the questions and responses described above, may be delivered in various 
forms of multimedia including without limitation, text, audio, video, animation, virtual reality 
and real-time audio and video. The necessary feedback required is calculated by a combination 
of factors such as student's overall progress through the simulation and various aspects of 
student's specific response to the question including: correctness as objectively compared to the 
prerecorded responses; voice volume, speed and stress levels; other aspects. A degree of 
correctness or a congruency factor is determined from these functions. External evaluators can 
also evaluate any or all of these factors and other factors. The external evaluators or the ICAT 
without the external evaluators' assistance may then direct the feedback required. The 
combination of the ICAT and any external evaluators makes up a "virtual director engine." 
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External evaluators can include domain experts and other inputs external to the simulation that 
can provide inputs to the simulation. 

After appropriate feedback and any remedial simulation is completed, the simulation continues. 
5 Student's next simulation will depend upon the student's individual success at completing the 
simulation thus far. If a student is progressing very well, the simulation may elevate the student 
to more difficult and complex simulations. If a student is progressing poorly, additional 
remedial simulations may be required. If a student is neither progressing poorly nor very well 
but somewhere in between the extremes, the next simulation may be a mixture of simple and 
10 complex issues. 

The simulation continuously tests the knowledge of the student and identify weaknesses then 
address those weaknesses through remedial training that is tailored to the precise weaknesses of 

JJ the student. 

1 15 

vpfFs 

|*j Guide to the Knowledge Base 

W A student may desire assistance to complete a simulation. In such an instance, the student may 

m need to query the knowledge base for directions and assistance such as: where to route a 

;f particular question from a customer; or, what is the precise company policy regarding a 

Spy 

bh 20 particular question; or, how to enter a service order; or, many other procedural or technical 

fi 

^ issues. 

y £ 

M 

The student may access the knowledge base using a simple text-query index system similar to 
many computer applications "Help" functions. As most computer users are aware, the user must 
25 know the precise word or phrase to find the needed information in such a text-query index 

system. The various methods for accessing the knowledge base are included in a set of functions 
referred to as a "help engine." 

One method of accessing the knowledge base would be an icon or button included in the 
30 student's training station. Such an icon or button may be located on the display or the keyboard 
or mouse or maybe other input devices. Selecting this button would cause a help menu of 
selections to be presented. The help menu selections may include: 
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Present Example 
Hint From Coach 
Enter Query 

(Additional selections may also be provided) 

Figure 81 illustrates the flow of a student query 8110 in a telephone operator simulation 8100. 

Selecting "Present Example" 8120 causes the knowledge base to search 8122 for the preferred 
example or target response of how to handle the current simulation the student is working 
through. Once the preferred response example is determined, the preferred response example is 
presented 8124 to the student. Figure 82 illustrates a multimedia presentation of a preferred 
example response 8200. The preferred example response 8200 may include a video component 
8210, a text component 8220, an audio component 8230, a example illustration 8240, and other 
components such as animation may also be included in the presentation of a preferred example 
response 8200. 

Returning to Figure 81, selecting "Hint From Coach" 8130 causes the knowledge base to search 
8132 for the next step of the preferred response. Once the next step of the preferred response is 
determined, the step is presented 8134 to the student. 

Selecting "Enter Query" 8140 causes the knowledge base to process the student query 8142. 
The knowledge base searches 8144 for related subjects. Presents a list of related subjects 8146. 
Student chooses the related subject to review 8148. The related subject is presented 8149. This 
is a more user friendly method of accessing the knowledge base than a simple text query 
described above. Instead of simply looking to the text entry the student inputs, this more 
intelligent method also includes "context" features to the search such as: evaluate the specific 
simulation the student is facing; the student's success with the simulation thus far; previous hints 
and feedback provided to this student; previous hints and feedback provided to other similarly 
situated students; previous queries by this student; previous queries by other similarly situated 
students; and many other factors that may be included. 
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The response to a student's query may be presented 8149 in any one of several methods and 
formats. The presentation 8149 may be a text instruction box, or animation or a video or stop 
action presentation showing an example of how to do the exact task asked of the student or 
combinations of these presentation methods. 

5 

In an example, the student may be presented with a simulation requiring the student to take an 
order for a new telephone service for a customer's home. The student, having no previous 
experience entering such orders, is unaware how to do so. The student selects "Present 
Example." An animated instructor-character appears on the display. The instructor steps 
10 through a complete simulation, explaining the process and showing the questions being asked in 
text, and/or audio, and/or video and/or animation. The animated instructor displays and explains 
the preferred order entry method with example information from the simulated customer. 

During the presentation of the example, the student may again select the icon or button to display 
015 the help menu. The same menu described above would be presented with additional choices of 

"Replay", "Return", "Pause". Selecting "Present Example" may present additional detail from 
Pi the preferred example. Selecting "Hint From Coach" presents more detailed explanation of the 
m last step presented. Selecting "Enter Query" provides a text box for the student to enter queries 
J regarding the current preferred example. Selecting "Replay" restarts the presentation of the 

ih 20 preferred example method. Selecting "Pause" pauses the presentation of the preferred example 

fi and displays an icon or button to "Resume" or "Continue" the presentation of the preferred 

in 

0 example. Selecting "Return" ends the presentation of the preferred example and the simulation 
reverts back to the same point where the student first selected "Present Example." 

25 At the end of the presentation of the preferred example, the simulation reverts back to the same 
point where the student first selected "Present Example." 

Review and update the simulation 

As the training continues, the ICAT records the student's responses that are different than the 
30 responses recorded by the domain expert. At some later time, the ICAT reviews these responses 
with the domain expert so that the domain expert may assist the ICAT in properly classifying the 
responses as preferred, non-preferred, etc and properly provide feedback to student. 
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Since this process "learns" from new material from students, it is superior that previous 
computer based training processes. In addition the multiple methods and levels of feedback 
enable the ICAT to provide individualized feedback to each student. 

5 

The simulations may vary from very basic as described above to very complex with many levels 
and directions of training. Using the above example of telephone operator training, the first two 
comments, which are very basic, simple issues for a telephone operator to handle. If the student 
responses to these simulations were the preferred responses, the ICAT would direct that student 
10 down a more difficult task so as to continue to challenge the student. 

Multiple Students 

Simulations may also include the facility for multiple students to participate simultaneously. 
Figure 83 illustrates multiple students 8310, 8320, 8330, connected to the simulation server 8340 
5 15 via a local connection 8350, via a internet or wide area network (WAN) connection 8360, and a 
microwave satellite link 8370. Any other method of interconnecting computers could also be 
utilized. 



m 



25 



Expanding upon the above telephone operator training example, the simulation might also 
include: two students as operators taking customer calls; a third student handling technical 
support calls and referrals from the first two students; a fourth student, a more experienced 
telephone operator receiving more advanced training, as a telephone operator-supervisor 
handling issues the other students were unqualified to handle. To add difficulty, a student may 
even fill in the role as a customer. Other roles for additional students may also be included. 



Each of the students' responses would be processed similar to the individual student described 
above. The ICAT would use the inputs from the multiple students to determine the feedback, 
direction, and difficulty of the simulation for each student. The ICAT may include multiple 
students in a single simulation so that the students may interact or the ICAT may maintain each 
30 student in separate simulations for individual training. 
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Figure 84 is a block diagram of a system environment in accordance with a preferred 
embodiment. A server computer 84000 includes server system software such as a Lotus Domino 
Server, with various databases for schedules, email, discussion centers, knowledge data and 
global directory information including users 84001. In addition, advanced collaboration support 
5 is provided including support for a virtual classroom 84010. The server 84000 includes support 
for an internet protocol network 84020 including a dialup access server 84100 that 
communicates through a telephone company switched network 84120 to a remote System 
Management Environment (SME) 84200 to a remote computer 84220. This includes support for 
mobile devices such as palm pilots, two-way pagers, windows CE systems and wireless 
10 intelligent telephones. On-site SME 84250 is also supported from the IP network 84020. This 
support includes support for most Microsoft Windows 95/NT workstations such as those 
typically used for user desktop applications 84500. The IP Network 84020 also provides firewall 
Virtual Packet Network (VPN) access 84300 through the Internet 84310 to other firewall VPN 
access 84320 for subscribed users 84400 to provide access to applications to all users 84500. 



a is 

jpj Figure 85 is a block diagram of a virtual consulting channel in accordance with a preferred 

W embodiment. The virtual consulting channel is a subscription-based service offering used to 

y * 

jh deliver dynamic content and tools (business simulations, presentations, diagnostic tools, etc.) 

J . brought together by a content aggregator to develop awareness, create / sustain relationships and 

g«fe 

20 provide premium services to a client base utilizing a dynamic publishing paradigm for 

continuous refreshment of knowledge. A professor, teacher or other consultant prepares content 
C3 which can take the form of presentations, papers, homework assignments, web pages, 

simulations, tests, research assignments or reading assignments that are published as shown in 
function block 85110. The publisher 851 10 dynamically publishes the material as shown in 

25 function block 85120 after assuring that all the material is present and converts the information 
for use in collaboration 85131, scheduling / calendaring 85132, knowledge repository 85133, 
virtual training 85134, virtual meetings / rooms 85135 or news / profile 85136. The information 
is published utilizing an interface 85140 to subscribed users 85150 and public users 85160. 
Public content and media information from the Internet 85170 can be dynamically published or 

30 obtained from a subscription base 85185 through the content development function 85180. 
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A critical element of any virtual consulting channel will be the services that it provides to its 
subscribers. The Virtual Delivery Channels represent the access points to the underlying 
services that are provided for within the channel There is no limit to the type of virtual delivery 
channels that could exist and the beauty of a virtual channel is that new delivery channels can be 
5 added quite easily. Here are some examples of the type of virtual delivery channels that could be 
used. 

Collaboration - would provide the ability to create a collaborative environment between the user 
and Subject Matter Expert (SME) or create peer-to-peer collaboration between other subscribers 
1 0 with similar issues . 

Scheduling / Calendaring - would provide the ability to provide scheduled times (ie. Office 
Hours) for SMEs to interact with subscribers one-on-one or as a group, also to provide a calendar 
of events/activities which the subscriber would be 
interested in. 

0 15 Knowledge Repository - would provide access to a knowledge repository of high-value content, 
such as: business simulations, presentations, pre-recorded training sessions, etc. 
Virtual Training - would provide for delivering real-time, facilitated training sessions via the 
Iff channel led by a channel SME delivered to many subscribers at one time. 
! Virtual Meetings /Rooms - would provide for a virtual meeting capability between the 

M 20 subscriber and a SME. This capability would also allow for a private room to be used as a work- 
in-process room for subscriber interactions with channel SMEs. 

Industry News - would provide for a push channel of information that would be relevant and 
could be targeted to each subscriber based on their preferences. Obviously, channel news would 
also be intermingled with the industry news. 
25 Forums - would provide for a meeting place between subscribers around hot topics of interest. 
Tools - provide downloadable diagnostic tools (with virtual coaches) that could be used by the 
subscriber. 

Figures 86 is a data structure entity relationship diagram for a virtual consulting environment in 
30 accordance with a preferred embodiment. The students data structure 86000 encapsulates 
information about each student comprising name, address, telephone number, student 
identification and year in school. Each student in the student entity has zero to many student 



ky 



199 



) . ; 

AND1P045.P "" ? 



class schedules 86010 throughout the course of his tenure at school. By the same token, every 
class schedule belongs to a single student. Each student class schedule 86010 consists of zero to 
many classes 86030 and each class is a part of zero to many class schedules. Each instructor 
class schedule 86020 comprises zero to many classes and any single class 86030 is a part of zero 
5 to many instructor class schedules 86020. A class 86030 is an instance of a course 86100 

offered at a unique time. Each course 86100 has zero to many classes 86030 associated with it. 
Each class 86030 comprises zero to many class materials 86040 and class materials can be a part 
of one to many classes 86030. Class materials comprise links 86050, readings 86060, tests 
86070 and assignments 86080. An instructor class schedule 86020 belongs to one and only one 
10 instructor while an instructor can have zero to many instructor class schedules 86020. Each 

instructor 86090 may be in charge of zero to many courses 86100 while each course 86100 may 
be coordinate by one to many instructors 86090. The administration entity data structure 86110 
contains information pertaining to the administrative personnel for the university. 

if ; "I 

O 1 5 Figures 87 - 96 are flowcharts of a virtual university system in accordance with a preferred 
X embodiment. Processing commences at function block 87000 when a connection is made 

W through the internet to a website associated with the virtual university such as www.vu.edu . A 

jfj'jj 

m test is made at decision block 87010 to determine where the web traveler would like to venture. 

The first destination is the student union at decision block 87030. If the student union is the 
U 20 destination then at function block 88000 the traveler enters the student union which is detailed in 
yij Figure 91 . If the traveler wants to utilize a bulletin board for various functions detailed in Figure 

O 91, then the bulletin board function is used at function block 88010. Finally, if the traveler wants 

to conduct collaborations with other persons in the virtual university, then the collaboration 
function is utilized at function block 88020 and control is passed back to label A 87020. 

25 

If a traveler entering the virtual university desires to use the library as detected at decision block 
87040, then the various resources comprising links, articles and whitepapers are presented in 
function block 87050. Function block 87070 provides access to a librarian and function block 
87080 provides access to collaboration for conversing with other virtual university travelers. A 
30 list of active virtual university active participants is provided to select collaborators from. 

Finally, control is passed back to label A 87020 for further travel through the virtual university. 
Detailed processing for the library is provided in Figure 92. 
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A label DD 87060 is provided to gain access to the administrative offices through decision block 
88030. If administrative functions are desired, then course registration is provided at function 
block 88050, a university directory is provided at function block 88060, a class locator is 
5 provided at function block 88070, an administrative help desk is provided at function block 
88080, add/drop processing is provided at function block 88090, a career center is provided at 
function block 88100 and then processing is returned to label A 87020. Detailed processing for 
the administrative functions is provided in Figures 93 and 94. 

1 0 Further destinations for travelers in the virtual university are provided through label B 88040 
which traverses to Figure 89. In Figure 89, an instructor lookup function is provided at function 
block 89010. A label BB 89030 provides direct access to a professor's virtual office. Decision 
block 89020 searches for a particular instructor (professor) name, and if the name is found, then 
at function block 89040, the professor's virtual office is entered and if office hours are in effect, 
H 15 then a student can interact with the professor in a chat room. A Frequently Asked Questions 
|*J (FAQ) is provided to assist students as shown in function block 89050. Function block 89060 
W provides old tests, function block 89070 provides classroom issues, function block 89080 
m provides classroom materials, 89090 provides class handouts, function blocks 89100 provides 
? research topics, function block 89110 provides professor office hours, and function block 89120 

U 20 provides homework assignments. Finally, at label A 87020, control is passed back for further 
JJJ travel through the virtual university. 

Is: is 

If the traveler desires further class access as detected at decision block 89210, then function 
block 89230 provides a class directory. If class access is not desired at decision block 89210, 

25 then control is passed via label a 87020 for further travel through the virtual university. Function 
block 89240 provides class materials, function block 89250 provides access to a student's 
grades, function block 89260 provides access to class announcements, function block 89270 
provides access to class homework, function block 89280 provides access to tests, function block 
89290 provides access to class schedules, function block 89300 provides access to a breakout 

30 room, function block 89310 provides access to research topics and function block 89320 

provides access to lectures. Finally, at label A 87020 control is passed back to provide further 
travel through the virtual university. 
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Figure 90 provides detailed logic on directory processing in accordance with a preferred 
embodiment. Processing commences at function block 90000 where a class directory is accessed 
to provide the location of a class at function block 90100, the time of the class at function block 
5 90110, the date of the class at function block 90120 and entry to the class is provided via label 
CC 90010. From label CC 90010, control is passed to function block 90200 for student 
interaction. A label DD 90150 is provided to directly branch to student collaboration at function 
block 90140. Collaboration functions include e-mail to a student at function block 90160, voice 
or video mail at function block 90170, contact information at function block 90180 and finally a 
1 0 branch back via label AA 90190 to provide professor directory processing. 

Function block 90230 provides professor lookup via a branch to label BB 89030. Similarly, the 
administrative directory functions are provided via function block 90240 via a branch through 
label DD 90150. Finally, control is passed back to the calling function via return label 90260. 

|?» 
o 

O 15 Figure 91 provides detailed logic associated with student union processing in accordance with a 
|S preferred embodiment. Label A 91000 is provided to allow direct access to a menu of options in 

W function block 91010. Then, at decision block 91020, a test is performed to determine if bulletin 

m 

§]« board processing is desired. If so, then at function block 91030, a post to the bulletin board is 
provided to allow a traveler to post a new message. Function block 91040 allows a traveler to 
20 read a message, function block 91050 allows a traveler to respond to a bulletin board posting, 
p| function block 91060 allows a traveler to delete a bulletin board posting and function block 
O 91070 allows a traveler to append to a bulletin board posting. Finally, via label A 91000 control 
is returned to the menu of options for further student union processing. 

25 If student union collaboration is desired as determined in decision block 91 100, then a list of 
active people is presented to the traveler at function block 91120 and selections are allowed at 
function block 91130 and a test is performed to determine if chat or collaboration are desired at 
decision block 91140. A label SU1 91110 is provided for direct entry to the collaboration 
function. Also, if no collaboration is desired, then at decision block 91150 a test is performed to 

30 determine if exit from the student union is desired. If so, then control is returned at label 91160. 
If not, then control is returned via label A 91000 to the menu of options. If collaboration or chat 
is not desired, then control is passed via label A 91000. Collaboration is enabled for video at 
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function block 91170, for audio at function block 91180, for text at function block 91190, for 
whiteboard at function block 91200, for application sharing at function block 91210 and for 
internet browsing at function block 91220. Finally, control is passed via label A 91000 back to 
the menu of student union options. 

5 

Figure 92 presents the detailed logic for the virtual library in accordance with a preferred 
embodiment. A label LI 92000 is provided to facilitate library processing. At decision block 
92010, a test is performed to determine what resources are desired. At function block 92020 a 
list of resources is presented and at function block 92030 a traveler is asked to select the desired 
1 0 resource. Function block 92040 allows a user to view the resource. Function block 92050 
allows a user to print a resource. Function block 92060 allows a user to save a resource. 
Function block 92070 allows a user to e-mail a link to a particular resource to another user to 
allow the user access to the resource. Finally at label LI 92000, control is passed back to 
% facilitate other library functions. At decision block 92080 a test is performed to determine if a 
P 15 virtual librarian is desired. If so, then resources are reserved at function block 92230 such as 
m books, microfilm, articles and other library material. Then, at function block 92240 questions 
W can be asked of the librarian and control is passed via label LI 92000 for further virtual library 
§1 functions. Decision block 92100 determines if collaboration is desired. If so, then processing is 
I . passed via label SU1 91 1 00 to process the collaboration. If not, then a test is performed at 
¥ 20 decision block 92210 to determine if exit from the library is desired. If so, then control is 
m returned at label 92220, and if not, then control is passed via label LI 92000 for further library 
p processing. 

hk 

Figure 93 and 94 provide detailed logic on administrative office functions in accordance with a 
25 preferred embodiment. Processing commences at label A01 93000 and an immediate test is 
performed at decision block 93100 to determine if course registration should commence. If so, 
then at label CR1 93110 function block 93120 allows a traveler to view courses and function 
block 93130 allows a user to select a course and if a traveler decides at decision block 93140 to 
attempt registration, then the traveler can view the course details at function block 93150. If the 
30 course is full at decision block 93160, then control is passed back to function block 93120 to 

view other courses. If not, then the student is registered at function block 93170 and the student 
is billed at function block 93180. Then, control is returned via label A01 93000 for further 
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administrative office processing. If a university directory search is desired, then an entry is 
searched against the university database in function block 93310, function block 93320 provides 
a view of directory information of persons or entities. Function block 93330 provides a copy of 
information to a travelers personal directory and a test is performed at decision block 93340 to 
5 determine if a directory search for a student, professor or administrative function is needed. If 
so, then control is passed via DDI 90150. If not, then control is passed via label AOl 93000. 

If a class locator is desired at decision block 93210 then control is passed via label CL1 89210 to 
locate the class. If a administrative help desk is desired, then function block 93350 provides 
1 0 answers to questions, and at function block 93360 Frequently Asked Questions (FAQ)s are 
answered. Then, a test is performed decision block 93370 to determine if collaboration is 
desired. If so, then control is passed via label SU1 91110 to determine the proper form of 
collaboration and perform the function. If collaboration is not desired, then control is passed 

K back via AOl 93000 for further processing in the virtual administrative offices. If no help is 

0 1 5 necessary then control is passed via label A02 9401 0. 

W Figure 94 provides additional detailed logic for administrative office in accordance with a 
Jl preferred embodiment. Control enters via label A02 94010 and a test is performed to determine 
if if add / drop is desired. If so, then at function block 94000 the schedule can be viewed and at 

P 20 decision block 94100 an addition of the course is performed via label CR1 93110. If not, then if 
jA a drop is desired, then the course is removed at function block 94120 and the student's bill is 
0 updated at function block 94130 and control is passed via label AOl 93000. If a career center 
review is desired as detected at decision block 94030, then at function block 94040 Frequently 
Asked Questions (FAQ)s are presented. Function block 94050 presents job postings for 
25 available positions, function block 94060 presents career research companies to provide 
assistance with jobs, function block 94070 presents signup information for interviews and 
function block 94080 facilitates submission of a resume. Finally, at label AOl 93000 control is 
returned for further administrative office processing. 

30 Figure 95 presents the detailed logic associated with virtual classroom processing in accordance 
with a preferred embodiment. Processing commences at function block 95000 when a traveler 
enters the classroom. A list of students is presented in decision block 95010, then at function 
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block 95020 a student can enter a chat room or at function block 95030 a student can enter a 
collaboration and control is returned to label A 95001. A test is performed at decision block 
95040 to determine if a student desires to participate in a class. If so, then at function block 
95050 a student can listen to a lecture, at function block 95060, a student can watch a video, at 
function block 95100 a student can watch a presentation, at function block 95110 a student can 
collaborate with a class, function block 95120 a virtual hand raise to be recognized for 
participation is handled, function block 95130 interactive browsing is performed, function block 
95140 an assignment can be submitted and at function block 95150 a test can be taken and 
control is returned to label A 95001. 



If instruction is desired as detected at decision block 95300, then a lecture can be presented in 
function block 95400, a presentation is displayed at function block 95410, a collaboration is 
initiated at function block 95420, a moderation is performed at function block 95500, breakout 
groups or rooms are initiated at function block 95600 and a session is recorded at 95610 and 
p1 1 5 control is returned to label A 95001 . 



If lessons are to be created as detected at decision block 95310, then presentations are created in 
function block 95200, create videos in function block 95210, create links as in function block 
95220, create a simulation in function block 95230, add materials to the resource center in 
* 20 function block 95240, create assignments in function block 95250 and create tasks in function 
block 95260 and control is returned to label A 95001. Then, via label g 95320 control is passed 
to a decision block to determine if the traveler desires entry into the resource center. At function 
block 96100 materials can be viewed, at function block 96110 past sessions can be viewed, at 
function block 96120 assignments can be viewed, at function block 96130 Frequently Asked 
25 Questions (FAQ)s can be reviewed, at function block 96140 assignments can be submitted, at 
function block 96150 past tests can be reviewed and at function block 96160 feedback can be 
submitted to the instructor. Finally, control is returned label 96200 or 96210. 

Figure 97 is a flowchart presenting the detailed logic for virtual consulting in accordance with a 
30 preferred embodiment. The logic commences at decision block 97000 when a traveler decides 
whether to enter the virtual reception area. If entry is desired, then at function block 97010 a 
directory listing is obtained, from the directory listing, calls can be placed, e-mails, chatrooms 
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entered, collaborations commenced as discussed above at label 90150 in Figure 90. Function 
block 97020 provides processing for questions directed to the receptionist and function block 
97030 for collaboration processing as discussed in Figure 90. Function block 97040 presents a 
list of meetings for scheduling purposes and to determine what meeting is appropriate to attend 
and to perform meeting management. Actions for meeting management comprise attending a 
meeting, scheduling a meeting, rescheduling a meeting, canceling a meeting, invitations to 
meeting, add items for use in the meeting such as papers, presentations or simulations and 
reserving an appropriate room. Other meeting management functions include whether the 
meeting is a public or private meeting. If it is private only the invited attendees are allowed to 
attend the meeting. If it is public, then others can drop by and interrupt. A graphical user 
interface portrays the type of meeting utilizing an appropriate indicia such as color, label or 
graphical item. When meeting management is completed control is returned to label A 97001. 

Decision block 97050 determines whether the traveler will attend a meeting. If so, then at 
function block 97060, a traveler can listen and view the material for the meeting, at function 
block 97070 a traveler can collaborate in a meeting, at function block 97080 a traveler can record 
a meeting to a server or the traveler's computer, at function block 97090 a traveler can see a list 
of other attendees to a meeting and control is returned to label A 97001 . 

A decision is made at decision block 97200 to decide if the traveler desires to enter into a project 
room, Then, at function block 97210 a user can view a listing of all the people that are active in 
the project and perform directory functions such as those discussed with reference to Figure 90. 
Function block 97220 allows a traveler to review artifacts such as project deliverables, 
presentations and other materials. Then, at function block 97230 a traveler can add artifacts, or 
edit artifacts as shown in function block 97240 and control is passed via label A 97001. An 
artifact can be deleted at function block 97250 and collaboration is performed at function block 
97260 as detailed in Figure 90. Function block 97270 processes newsgroups such as threads 
associated with a topic of interest to the traveler and function block 97280 processes discussion 
groups such as an interactive chat session or collaboration concerning a point of interest with 
multiple participants. Finally control is returned via label A 97001. 
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If a traveler desires entry into a library as determined at decision block 97160, then at function 
blocks 97100 - 97150 processing is performed as discussed above in the virtual university 
library with reference to Figure 92. Figure 98 presents the detailed logic associated with offices 
and lounges in accordance with a preferred embodiment. A test 98000 determines if a virtual 

5 office is to be entered, if so, then at function block 98010, artifacts are processed in a manner 
similar to resource procesing as detailed in the library with reference to Figure 92. Collaboration 
is also provided in function block 98020 as detailed in Figure 90 and control is passed via label 
A 97001 . A test 98030 is performed to determine if a traveler desires entry into a virtual lounge. 
If so, then functions such as bulletin board 98100, newsgroups 98110, discussion groups 98120, 

1 0 list of active people 98130 and collaborations 98140 are handled as described earlier with 
reference to the student union in Figure 87. Functions such as view 98150, add 98160, edit 
98170 and delete 98180 are provided for the bulletin board, newsgroups and discussion groups. 
Then, control is returned via label A 97001 . 

if: ;? s 

C5 1 5 Figure 99 is a flowchart depicting the detailed logic for collaboration in accordance with a 
J5 preferred embodiment. Processing commences at function block 99010 when an Internet 
W Protocol connection is established for two or more users. The connection is initiated by a user 
iyi selecting another user's icon with information defining the IP address associated with the user. 
? . The two IP addresses are connected utilizing H.323 for audio or video teleconferencing or T.120 

fr- 20 for application sharing, whiteboarding and chat room support. 

P 

P The T. 1 20 standard contains a series of communication and application protocols and services 
that provide support for real-time, multipoint data communications. These multipoint facilities 
are important building blocks for a whole new range of collaborative applications, including 
25 desktop data conferencing, multi-user applications, and multi-player gaming. 

Broad in scope, T.120 is a comprehensive specification that solves several problems that have 
historically slowed market growth for applications of this nature. Perhaps most importantly, 
T.l 20 resolves complex technological issues in a manner that is acceptable to both the 
30 computing and telecommunications industries. 

Established by the International Telecommunications Union (ITU), T.120 is a family of open 
standards that was defined by leading data communication practitioners in the industry. Over 100 
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key international vendors, including Apple, AT&T, British Telecom, Cisco Systems, Intel, MCI, 
Microsoft, and PictureTel, have committed to implementing T.120-based products and services. 



While T.120 has emerged as a critical element in the data communications landscape, the only 
information that currently exists on the topic is a weighty and complicated set of standards 
documents. This primer bridges this information gap by summarizing T. 120's major benefits, 
fundamental architectural elements, and core capabilities. 



Key Benefits of T.120 

So why all the excitement about TT20? The bottom line is that it provides exceptional benefits 
to end users, vendors, and developers tasked with implementing real-time applications. The 
following list is a high-level overview of the major benefits associated with the T.120 standard: 



Multipoint Data Delivery 

T.120 provides an elegant abstraction for developers to create and manage a multipoint domain 
with ease. From an application perspective, data is seamlessly delivered to multiple parties in 
"realtime." 



Interoperability 

T.120 allows endpoint applications from multiple vendors to interoperate. T.120 also specifies 
how applications may interoperate with (or through) a variety of network bridging products and 
services that also support the T.120 standard. 



Reliable Data Delivery 

Error-corrected data delivery ensures that all endpoints will receive each data transmission. 



Multicast Enabled Delivery 

In muliticast enabled networks, T.120 can employ reliable (ordered, guaranteed) and unreliable 
delivery services. Unreliable data delivery is also available without multicast. By using 
multicast, the T.120 infrastructure reduces network congestion and improves performance for the 
end user. The T.120 infrastructure can use both unicast and multicast simultaneously, providing 
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a flexible solution for mixed unicast and multicast networks. The Multicast Adaptation Protocol 
(MAP) is expected to be ratified in early 1998. 

Network Transparency 

5 Applications are completely shielded from the underlying data transport mechanism being used. 
Whether the transport is a high-speed LAN or a simple dial-up modem, the application developer 
is only concerned with a single, consistent set of application services. 

Platform Independence 

1 0 Because the T. 1 20 standard is completely free from any platform dependencies, it will readily 
take advantage of the inevitable advances in computing technology. In fact, DataBeam's 
customers have already ported the T.120 source code easily from Windows to a variety of 
environments, including OS/2, MAC/OS, several versions of UNIX, and other proprietary real- 

i time operating systems. 



015 



Network Independence 

The T.120 standard supports a broad range of transport options, including the Public Switched 
Telephone Networks (PSTN or POTS), Integrated Switched Digital Networks (ISDN), Packet 
L Switched Digital Networks (PSDN), Circuit Switched Digital Networks (CSDN), and popular 
M 20 local area network protocols (such as TCP/IP and IPX via reference protocol). Furthermore, 

these vastly different network transports, operating at different speeds, can easily co-exist in the 
J*f same multipoint conference. 



Support for Varied Topologies 

25 Multipoint conferences can be set up with virtually no limitation on network topology. Star 

topologies, with a single Multipoint Control Unit (MCU) will be common early on. The standard 
also supports a wide variety of other topologies ranging from those with multiple, cascaded 
MCUs to topologies as simple as a daisy-chain. In complex multipoint conferences, topology 
may have a significant impact on efficiency and performance. 



30 



Application Independence 
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Although the driving market force behind T.120 was teleconferencing, its designers purposely 
sought to satisfy a much broader range of application needs. Today, T.120 provides a generic, 
real-time communications facility that can be used by many different applications. These 
applications include interactive gaming, virtual reality and simulations, real-time subscription 
5 news feeds, and process control applications. 

Scalability 

T.120 is defined to be easily scalable from simple PC-based architectures to complex multi- 
processor environments characterized by their high performance. Resources for T.120 
10 applications are plentiful, with practical limits imposed only by the confines of the specific 
platform running the software. 

Co-existence with Other Standards 

T.120 was designed to work alone or within the larger context of other ITU standards, such as 
1 5 the H.32x family of video conferencing standards. T.120 also supports and cross-references other 
important ITU standards, such as V.series modems. 

Extendability 

The T.120 standard can be freely extended to include a variety of new capabilities, such as 
20 support for new transport stacks (like ATM or Frame Relay), improved security measures, and 
new application-level protocols. 

Application-level Interoperability 

The upper levels of T.120 specify protocols for common conferencing applications, such as 
25 shared whiteboarding and binary file transfer. Applications supporting these protocols can 

interoperate with any other application that provides similar support, regardless of the vendor or 
platform used. This interoperability will exist in simple point-to-point conferences as well as 
large multipoint conferences using a conference bridge. 

30 The H.323 standard provides a foundation for audio, video, and data communications across IP- 
based networks, including the Internet. By complying to H.323, multimedia products and 
applications from multiple vendors can interoperate, allowing users to communicate without 
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concern for compatibility. H.323 will be the keystone for LAN-based products for consumer, 
business, entertainment, and professional applications. 

H.323 is an umbrella recommendation from the International Telecommunications Union (ITU) 
that sets standards for multimedia communications over Local Area Networks (LANs) that do 
not provide a guaranteed Quality of Service (QoS). These networks dominate today's corporate 
desktops and include packet-switched TCP/DP and IPX over Ethernet, Fast Ethernet and Token 
Ring network technologies. Therefore, the H.323 standards are important building blocks for a 
broad new range of collaborative, LAN-based applications for multimedia communications. 
The H.323 specification was approved in 1996 by the ITU's Study Group 16. Version 2 was 
approved in January 1998. The standard is broad in scope and includes both stand-alone devices 
and embedded personal computer technology as well as point-to-point and multipoint 
conferences. H.323 also addresses call control, multimedia management, and bandwidth 
management as well as interfaces between LANs and other networks. 

Then, at function block 99020 the application for collaboration is selected for the two or more 
users. A user selects a mode of collaboration such as a chat room audio, video, application 
sharing or white boarding and if necessary selects the application to share. Then, at function 
block 99030, the application is initiated and the two or more users are synchronized to the 
collaborative session at function block 99040 and the control is synchronized at function block 
99050. Then, the two or more users collaborate until they are finished and exit at function block 
99060. 

A user interface for communicating the status of a person or other entity could include color to 
denote the status of the person. So for example, a person that was unavailable for a meeting 
could be denoted with an indicia denoting their status. This indicia could be a graphical 
character, for example a telephone to the ear of the party denoting they are on the telephone, or 
the color red to indicate they were not to be disturbed. One of ordinary skill in the art will 
readily comprehend that other indicia may be utilized to communicate effectively the current 
status of a person or other entity. 
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Agents in the form of software programs to perform specific actions on behalf of a user can be 
utilized to complete tasks such as scheduling appointments, identifying availability of persons, 
searching for resources or retrieving information. Mobile devices such as cellular phones, 
window CE devices and two-way pagers can also launch agents and perform other actions in the 
environment such as collaborations. A dashboard can be utilized to summarize real-time 
information for a user based upon a personal profile specified by a user and stored in a database. 
Summaries include e-mail, voicemail, calendars, todo lists, person status and personalized 
newsfeeds. 

While various embodiments have been described above, it should be understood that they have 
been presented by way of example only, and not limitation. Thus, the breadth and scope of a 
preferred embodiment should not be limited by any of the above-described exemplary 
embodiments, but should be defined only in accordance with the following claims and their 
equivalents. 
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